代码中的天真编译错误

时间:2013-02-08 18:49:48

标签: c++

我有这段代码:

#include<iostream>
#include<algorithm>

#define mod 1000000007

using namespace std;
unsigned long long int pow(int);
unsigned long long int binomialCoeff(int ,int );
int i,j;
int T[1000][1000];

int main()
{
    unsigned long long int t,k,n,ans;
    cin>>t;
    while(t--)
    {
        ans=0;
        cin>>n;
        int a[n];
        for(i=0;i<n;i++)
        cin>>a[i];

        if(n%2==0)
            ans=(pow(n-1)-((binomialCoeff(n,n/2))/2))%mod;
        else
            ans=pow(n-1)%mod;

        printf("%lld\n",ans);
    }

    system("pause");
}

unsigned long long int binomialCoeff(int na,int rb)
{

    for(i=0;i<na-rb+1;i++)
        **T[i,0]=1;**

    for(i=0;i<rb+1;i++)
        **T[i,i]=1;**

    for(j=1;j<rb+1;j++)
    {           
        for(i=j+1;i<na-rb+j+1;i++)
            **T[i,j]=T[i-1,j-1]+T[i-1,j];**
    }
    return (T[na,rb]);
}


unsigned long long int pow(int n)
{
    int k;

    if(n==0)
        return 1;
    else if(n%2==0)
        {k=pow(n/2);return ((k%mod)*(k%mod))%mod;}
    else
        {k=pow(n/2);return ((((k%mod)*(k%mod))%mod)*2)%mod;}
}

我有这个算法:

2^(n-1) - ((1+(-1)^n)/4)*binomial(n, n/2)

... for this question

但是在我的编译器中我遇到了编译错误:

In function `long long unsigned int binomialCoeff(int, int)': 
   incompatible types in assignment of `int' to `int[1000]' 
   invalid operands of types `int[1000]' and `int[1000]' to binary `operator+' 
   invalid conversion from `int*' to `long long unsigned int' 

1 个答案:

答案 0 :(得分:4)

您的阵列访问语法错误。尝试:

T[i][0] = 1;

在您对多维数组的所有使用中都是如此。例如,稍后,这个:

// Bad code from original post
T[i,j]=T[i-1,j-1]+T[i-1,j]

应写成:

T[i][j]=T[i-1][j-1]+T[i-1][j];