NOJ 212题K尾相等数

举报
Linux猿 发表于 2021/08/05 22:52:40 2021/08/05
【摘要】 题目链接~~>        这题属于简单题,本来不想写进博客,但看了别人的优代码,真没想到那种方法,比较好。我用的快速幂然后开始遍历,时间可想而知。。。 代码(本人): #include<stdio.h>int pow(int b,int m)//快速幂{ int ans=1; while(...

题目链接~~>

       这题属于简单题,本来不想写进博客,但看了别人的优代码,真没想到那种方法,比较好。我用的快速幂然后开始遍历,时间可想而知。。。

代码(本人):


  
  1. #include<stdio.h>
  2. int pow(int b,int m)//快速幂
  3. {
  4. int ans=1;
  5. while(b)
  6. {
  7. if(b%2)
  8. {
  9. ans=(m*ans)%1000;
  10. }
  11. b/=2;
  12. m=(m*m)%1000;
  13. }
  14. return ans;
  15. }
  16. int pss(int b,int n)
  17. {
  18. int ans=1;
  19. while(b)
  20. {
  21. if(b%2)
  22. {
  23. ans=n*ans;
  24. }
  25. b/=2;
  26. n=n*n;
  27. }
  28. return ans;
  29. }
  30. int main()
  31. {
  32. int T;
  33. long long m;
  34. int i,j,k,x,y,q;
  35. scanf("%d",&T);
  36. while(T--)
  37. {
  38. scanf("%lld",&m);
  39. if(m<1000)//让起点大于1000
  40. {
  41. q=m;
  42. for(i=1;i<=35;i++)
  43. if(pss(i,q)>=1000)
  44. break;
  45. }
  46. else {
  47. q=m%1000;
  48. i=1;
  49. }
  50. for(j=i;j<1000;j++)
  51. {
  52. int f=0;
  53. for(k=i;k<j;k++)
  54. {
  55. x=pow(j,q);
  56. y=pow(k,q);
  57. if(x==y)
  58. {
  59. f=1;
  60. break;
  61. }
  62. }
  63. if(f==1)
  64. break;
  65. }
  66. printf("%d\n",j+k);
  67. }
  68. return 0;
  69. }

代码(优):


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. long int n,k,i;
  5. scanf("%d",&n);
  6. while(n--)
  7. {
  8. scanf("%d",&k);
  9. long int a[1000]={0},t,flag=0;
  10. if(k>=1000)
  11. {
  12. k%=1000;
  13. a[k]++;
  14. flag=1;
  15. }
  16. for(t=k,i=2;;i++)
  17. {
  18. k=t*k;
  19. if(flag==1||k>=1000)
  20. {
  21. k%=1000;
  22. a[k]+=i;
  23. if(a[k]>i)//如果成立说明已经存过数
  24. break;
  25. }
  26. }
  27. printf("%d\n",a[k]);
  28. }
  29. }


 


 

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

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

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

评论(0

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

全部回复

上滑加载中

设置昵称

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

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

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