zoukankan      html  css  js  c++  java
  • HDUOJ------(1230)火星A+B

    火星A+B

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 9808    Accepted Submission(s): 3232


    Problem Description
    读入两个不超过25位的火星正整数A和B,计算A+B。需要注意的是:在火星上,整数不是单一进制的,第n位的进制就是第n个素数。例如:地球上的10进制数2,在火星上记为“1,0”,因为火星个位数是2进制的;地球上的10进制数38,在火星上记为“1,1,1,0”,因为火星个位数是2进制的,十位数是3进制的,百位数是5进制的,千位数是7进制的……
     
    Input
    测试输入包含若干测试用例,每个测试用例占一行,包含两个火星正整数A和B,火星整数的相邻两位数用逗号分隔,A和B之间有一个空格间隔。当A或B为0时输入结束,相应的结果不要输出。
     
    Output
    对每个测试用例输出1行,即火星表示法的A+B的值。
     
    Sample Input
    1,0 2,1
    4,2,0 1,2,0
    1 10,6,4,2,1 0 0
    Sample Output
    1,0,1
    1,1,1,0
    1,0,0,0,0,0
     
     1     #include<stdio.h>
     2     #include<string.h>
     3     #include<stdlib.h>
     4     int prime[27];
     5     bool isprime[121];
     6     //快速素数表
     7     void qiusu()
     8     {
     9         int i,j;
    10         memset(isprime,true,sizeof(isprime));
    11         isprime[0]=isprime[1]=false;
    12         for(i=0;i*i<120;i++)
    13             if(isprime[i]) 
    14                 for(j=2;j*i<120;j++)
    15                   isprime[j*i]=false;
    16         for(j=i=0;i<120;i++)
    17         {
    18             if(j>25)break;
    19             if(isprime[i])  prime[j++]=i;
    20         }
    21     /*    for(j=0;j<26;j++)
    22             printf("%d	",prime[j]);*/
    23        return ;
    24     }
    25     int work(char *str,int *aa)
    26     {
    27         int i,j,temp;
    28         for(j=i=0;str[i];i++)
    29             if(str[i]==',')  j++;
    30             else aa[j]=aa[j]*10+(str[i]-'0');  //     转化为数字
    31         /*翻转*/
    32         for(i=0;i<(j+1)/2;i++)
    33         {
    34             temp=aa[j-i];
    35             aa[j-i]=aa[i];
    36             aa[i]=temp;
    37         }
    38         return j;
    39     }
    40     int main()
    41     {
    42         int lena,lenb,i,cnt;
    43         char sa[100]={''},sb[100]={''};
    44         int aa[30]={0},bb[30]={0};
    45         qiusu();
    46         while(~scanf("%s%s",sa,sb))
    47         {
    48             memset(aa,0,sizeof(aa));
    49             memset(bb,0,sizeof(bb));
    50             if((sa[0]=='0'&&sa[1]=='')&&(sb[0]=='0'&&sb[1]==''))    break;
    51             lena=work(sa,aa);
    52             lenb=work(sb,bb);
    53             if(lena<lenb) lena=lenb;
    54             lena++;
    55             for(cnt=i=0;i<=lena;i++)
    56             {
    57               aa[i]+=bb[i]+cnt;
    58               cnt=(aa[i])/prime[i];
    59               aa[i]%=prime[i];
    60             }
    61             while(aa[lena]==0)     lena--;
    62             for(i=lena;i>0;i--)
    63                 printf("%d,",aa[i]);
    64             printf("%d
    ",aa[0]);
    65             memset(sa,'',sizeof(sa));
    66             memset(sb,'',sizeof(sb));
    67         }
    68         return 0;
    69     }
    View Code
  • 相关阅读:
    [Clr via C#读书笔记]Cp18 定制Attribute
    [Clr via C#读书笔记]Cp16数组
    [Clr via C#读书笔记]Cp17委托
    [Clr via C#读书笔记]Cp15枚举和位标识
    [Clr via C#读书笔记]Cp14字符字符串和文本处理
    [Clr via C#读书笔记]Cp13接口
    [Clr via C#读书笔记]Cp12泛型
    [Clr via C#读书笔记]Cp11事件
    [Clr via C#读书笔记]Cp10属性
    【程序员面试金典】面试题 02.06. 回文链表
  • 原文地址:https://www.cnblogs.com/gongxijun/p/3469910.html
Copyright © 2011-2022 走看看