NOJ 114 某种序列

举报
Linux猿 发表于 2021/08/05 23:05:48 2021/08/05
【摘要】 题目链接~~>           这一题和NOJ/655题光棍的yy以及HDU的大数斐波那契一样,都需要开一个二维的数组,做HDU的大数非波纳契和NOJ的光棍的yy时由于只有两个数相加我采用的是:只要两个数的相同位相加,然后判断是否大于 10…… 但是做某种序列时用就不行了,找了很久...

题目链接~~>

 

        这一题和NOJ/655题光棍的yy以及HDU的大数斐波那契一样,都需要开一个二维的数组,做HDU的大数非波纳契和NOJ的光棍的yy时由于只有两个数相加我采用的是:只要两个数的相同位相加,然后判断是否大于 10…… 但是做某种序列时用就不行了,找了很久的错,最后找数模拟了一下才发现原来三个数不能用上面的判断方法,因为三个数相加有可能进 2 ,并不一定进 1 ,恍然大悟!!

代码:


  
  1. #include<stdio.h>
  2. #include<string.h>
  3. int a[102][100];
  4. void huan(int x,int y)
  5. {
  6. int r=0;
  7. while(x)
  8. {
  9. a[y][r++]=x%10;
  10. x=x/10;
  11. }
  12. }
  13. int main()
  14. {
  15. int i,j,c,x1,x2,x3,mat;
  16. while(scanf("%d%d%d",&x1,&x2,&x3)!=EOF)
  17. {
  18. if(x1==0&&x2==0&&x3==0)
  19. {
  20. printf("0\n");
  21. continue;
  22. }
  23. memset(a,0,sizeof(a));
  24. huan(x1,1);
  25. huan(x2,2);
  26. huan(x3,3);
  27. for(i=4;i<=100;i++)
  28. {
  29. c=0;
  30. for(j=0;j<99;j++)
  31. {
  32. mat=a[i-1][j]+a[i-2][j]+a[i-3][j]+c;
  33. a[i][j]=mat%10;
  34. c=mat/10;
  35. }
  36. }
  37. for(i=99;i>=0;i--)
  38. if(a[100][i]!=0)
  39. break;
  40. for(j=i;j>=0;j--)
  41. printf("%d",a[100][j]);
  42. printf("\n");
  43. }
  44. return 0;
  45. }

优代码:


  
  1. #include<stdio.h>
  2. #include<string.h>
  3. void change(char *p,int *q,int l)
  4. {
  5. int i;
  6. for(i=0;i<l;i++)
  7. q[l-1-i]=p[i]-'0';
  8. }
  9. void add(int *a,int *b,int *c,int *f)
  10. {
  11. int i;
  12. for(i=0;i<100;i++)
  13. {
  14. f[i]+=a[i]+b[i]+c[i];
  15. if(f[i]>9)
  16. {
  17. f[i+1]+=f[i]/10;
  18. f[i]%=10;
  19. }
  20. }
  21. }
  22. int main()
  23. {
  24. char a[10],b[10],c[10];
  25. while(scanf("%s%s%s",a,b,c)!=EOF)
  26. {
  27. int l1=strlen(a),l2=strlen(b),l3=strlen(c);
  28. if(a[0]=='0' && b[0]=='0' && c[0]=='0') {printf("0\n");continue;}
  29. int i,j,n[100][100]={0};
  30. change(a,n[0],l1);
  31. change(b,n[1],l2);
  32. change(c,n[2],l3);
  33. for(i=3;i<100;i++) add(n[i-3],n[i-2],n[i-1],n[i]);
  34. for(i=99;n[99][i]==0;i--);
  35. for(;i>=0;i--)
  36. printf("%d",n[99][i]);
  37. printf("\n");
  38. }
  39. }


 


 

文章来源: blog.csdn.net,作者:Linux猿,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/nyist_zxp/article/details/9395879

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。