0
点赞
收藏
分享

微信扫一扫

CF 614B Gena\'s Code 大数处理

西红柿上校 2023-07-13 阅读 48

题意:给你n个数字,所有数字的长度之和不超过1e5,求这些数字的和(这些数字至多一个不是完美数,完美数



指只由0或1组成,且1至多一个)

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <algorithm>
#include <set>
using namespace std;
typedef long long ll;
typedef unsigned long long Ull;
#define MM(a,b) memset(a,b,sizeof(a));
const double eps = 1e-10;
const int inf = 0x3f3f3f3f;
const double pi=acos(-1);
const int mod=100000000;
ll max(ll a,ll b)
{return a>b?a:b;};
int min(int a,int b)
{return a<b?a:b;};

const int max_=100000;
char a[max_+5],nper[max_+5];

int main()
{
    int n;
    while(~scanf("%d",&n))
    {
        int zeronum=0,iszero=0;
        MM(nper,'\0');
        for(int i=0;i<n;i++)
        {
            int onenum=0,zerotemp=0,flag=1;;
            scanf("%s",a);
            if(a[0]=='0')
            {iszero=1;continue;}

            if(nper[0]=='\0')
            for(int j=strlen(a)-1;j>=0;j--)
                {
                    if(a[j]=='1') onenum++;
                    if((a[j]!='0'&&a[j]!='1')||onenum>1)
                       {
                           strcpy(nper,a);
                           flag=0;
                           break;
                       }//出现了非完美数
                }

            if(flag)  zeronum+=strlen(a)-1;
        }
        if(iszero) {printf("0\n");continue;}
        if(nper[0]!='\0')  printf("%s",nper);
               else printf("1");
        for(int i=0;i<zeronum;i++) printf("0");
        printf("\n");
    }
    return 0;
}



分析: 关键是完美数的理解,,只能是0,1,10,100,1000.。。。。这样的数字 ,因为数字很大所以要进行大数


处理

举报

相关推荐

0 条评论