牛筋鹏 2022-03-07 17:15 采纳率: 100%
浏览 66
已结题

pta中6-7完全平方数,有点不能理解为什么执行不出结果。求指导

#include <stdio.h>
#include <math.h>
int IsTheNumber ( const int N );
int main()
{
int n1, n2, i, cnt;
scanf("%d %d", &n1, &n2);
cnt = 0;
for ( i=n1; i<=n2; i++ ) {
if ( IsTheNumber(i) )
cnt++;
}
printf("cnt = %d\n", cnt);
return 0;
}
int IsTheNumber ( const int N )
{
int kpf,a,b,c,d;
if(sqrt(N)==(int)sqrt(N));
{
a=N/100;
b=N%10;
c=N/10;
d=c%10;
if(a==b||a==d||b==d)
{
return 1;
}
}
return 0;
}

  • 写回答

3条回答 默认 最新

  • 关注

    a=N/100;
    b=N%10;
    c=N/10;
    d=c%10;
    这里判断重复数字的方法不对,输入的N并不一定是3位数字,代码修改如下:

    #include <stdio.h>
    #include <math.h>
    int IsTheNumber ( const int N );
    int main()
    {
        int n1, n2, i, cnt;
        scanf("%d %d", &n1, &n2);
        cnt = 0;
        for ( i=n1; i<=n2; i++ ) {
            if ( IsTheNumber(i) )
                cnt++;
        }
        printf("cnt = %d\n", cnt);
        return 0;
    }
    int IsTheNumber ( const int N )
    {
        int a[10],t,i,j;
        if(sqrt((double)N)==(int)sqrt((double)N));
        {
            i=0;
            t = N;
            while(t)
            {
                a[i] = t%10;
                t/=10;
                //判断有无重复数字
                for(j=0;j<i;j++)
                {
                    if(a[j]==a[i])
                        return 1;
                }
                i++;
            }
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月15日
  • 已采纳回答 3月7日
  • 创建了问题 3月7日

悬赏问题

  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计