AOI6 2021-09-20 17:39 采纳率: 92.3%
浏览 46
已结题

C语言,完全平方数 区位图鬼地方个

Problem Description
判断从l到r中有多少个数的每一位都是完全平方数且这个数自身也是完全平方数

Input
t组数据,每组包含两个整数l,r

(0<=l<=r<=1000000)
1<=t<=1000000

Output
每组输出一个答案,表示从l到r有多少符合要求的数

SampleInput
2
1 10
30 100
SampleOutput
3
2

  • 写回答

1条回答 默认 最新

  • qzjhjxj 2021-09-20 21:55
    关注

    供参考:

    #include<stdio.h>
    
    // n^2=1+3+5+……+2n-1 n个奇数(1,3,5,7,...)之和等于n的平方,
    //其中n大于0 如果变成了负数,说明它不是平方数
    int isPerfectSquare(int num)
    {
        int i = 1;
        while (num > 0)
        {
               num -= i;
               i += 2;
        }
        return num == 0;
    }
    
    int main()
    {
        int i,t,l,r,n,k,cnt,a[7];
        scanf("%d",&t);
        while(t--)
        {
             scanf("%d%d",&l,&r);
             if(l<0 || l>r || r>1000000)//0<=l<=r<=1000000
                continue;
             cnt=0;
             for(i=l;i <= r; i++){
                    l = i; k=0;
                    for(n=0;n < 7;n++) a[n]=0;
                    while(l){
                          a[k++] = l%10;
                          l /= 10;
                    }
                    if(a[0]==2||a[0]==3||a[0]==7||a[0]==8)//个位数是2、3、7、8的整数一定不是完全平方数
                       continue;
                    if(a[0]%2==1 && a[1]%2==1)//个位数和十位数都是奇数的整数一定不是完全平方数
                       continue;
                    for(n=0; n < k;n++)
                       if(isPerfectSquare(a[n])!=1)//每一位都是完全平方数
                          break;
                    if(n >= k && isPerfectSquare(i)==1)//每一位都是完全平方数且这个数自身也是完全平方数
                       cnt++;
             }
             printf("%d\n",cnt);
        }
        
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月30日
  • 已采纳回答 9月22日
  • 创建了问题 9月20日

悬赏问题

  • ¥30 STM32 INMP441无法读取数据
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境