题意:给你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.。。。。这样的数字
,因为数字很大所以要进行大数
处理