第四个点一直wa,哪位大佬可以看一下么~

#include<bits/stdc++.h>
using namespace std;
string s;
int a[10005];
int jz,len;
int plus_(int n){
    int carry=0;
    int c[10005]={0};
    for(int i=0;i<n;i++){
        c[i]=a[i]+a[n-i-1]+carry;
        if(c[i]>=jz){
            c[i]=c[i]%jz;
            carry=1;
        }
        else carry = 0;
        //cout<<c[i]<<" ";
    }
    if(carry==1){
        n++;
        c[n-1]=1;
    }
    //cout<<c[n-1];
    for(int i=0;i<n;i++){
        a[i]=c[i];
    }
    return n;
}
bool judge(int a[]){
    for(int i=0;i<len/2;i++){
        if(a[i]!=a[len-i-1]) return false;
    }
    return true;
}
int main(){
    cin>>jz>>s;
    len = s.size();
    for(int i=0;i<len;i++){
        if(s[i]-'0'<10) a[i]=s[i]-'0';
        else if(s[i]-'A'<=5) a[i]=s[i]-'A'+10;
    }
    //len = plus_(len);
    int cnt=0;
    while(cnt<=30){
        if(judge(a)){
            cout<<"STEP="<<cnt<<endl;
            return 0;
        }
        else{
            cnt++;
            len = plus_(len);
            //print();
        }
    }
    cout<<"Impossible"<<endl;
    return 0;
}

1 条评论

  • @ 2017-07-17 22:34:45

    我傻逼了,“Impossible!”要加感叹号》——《

    • @ 2017-08-15 13:31:50

      我kao 我也是因为你这个原因卡了好久 谢谢!!

  • 1

信息

ID
1304
难度
5
分类
模拟 点击显示
标签
递交数
8080
已通过
2532
通过率
31%
被复制
31
上传者