提交记录 28018


用户 题目 状态 得分 用时 内存 语言 代码长度
xujindong 1002. 测测你的多项式乘法 Accepted 100 190.651 ms 40616 KB C++14 942 B
提交时间 评测时间
2025-03-14 15:02:18 2025-03-14 15:02:21
#include<bits/stdc++.h>
using namespace std;
int n,m;
complex<double>f[2097152];
void DIF(int n,complex<double>f[]){
  for(int i=n;i>=2;i>>=1){
    complex<double>wn(cos(2*M_PI/i),sin(2*M_PI/i));
    for(int j=0;j<n;j+=i){
      complex<double>w(1,0),x,y;
      for(int k=j;k<j+i/2;k++)x=f[k],y=f[k+i/2],f[k]=x+y,f[k+i/2]=w*(x-y),w*=wn;
    }
  }
}
void DIT(int n,complex<double>f[]){
  for(int i=2;i<=n;i<<=1){
    complex<double>wn(cos(2*M_PI/i),sin(2*M_PI/i));
    for(int j=0;j<n;j+=i){
      complex<double>w(1,0),x,y;
      for(int k=j;k<j+i/2;k++)x=f[k],y=w*f[k+i/2],f[k]=x+y,f[k+i/2]=x-y,w*=wn;
    }
  }
  reverse(f+1,f+n);
  for(int i=0;i<n;i++)f[i]/=n;
}
void poly_multiply(unsigned a[],int n,unsigned b[],int m,unsigned c[]){
  for(int i=0;i<=max(n,m);i++)f[i]=complex<double>(a[i],b[i]);
  DIF(2<<__lg(n+m),f);
  for(int i=0;i<2<<__lg(n+m);i++)f[i]*=f[i];
  DIT(2<<__lg(n+m),f);
  for(int i=0;i<=n+m;i++)c[i]=f[i].imag()/2+0.5;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #1190.651 ms39 MB + 680 KBAcceptedScore: 100


Judge Duck Online | 评测鸭在线
Server Time: 2025-04-02 21:37:19 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠