当前位置: 代码迷 >> 综合 >> PAT-4-7 统计某类完全平方数 (20分)
  详细解决方案

PAT-4-7 统计某类完全平方数 (20分)

热度:107   发布时间:2023-10-09 21:43:03.0
4-7 统计某类完全平方数   (20分)

本题要求实现一个函数,判断任一给定整数N是否满足条件:它是完全平方数,又至少有两位数字相同,如144、676等。

函数接口定义:

int IsTheNumber ( const int N );

其中N是用户传入的参数。如果N满足条件,则该函数必须返回1,否则返回0。

裁判测试程序样例:

#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;
}/* 你的代码将被嵌在这里 */

输入样例:

105 500

输出样例:

cnt = 6	


int IsTheNumber ( const int N ){int n,m,temp;m=N;n = (int)sqrt(N);if(n*n==m){int num[10]= {0};//这里应该定义num的长度为10,因为传入的整数的每位数可能是0~~9,而不是传入数的位数。 while(m>0){//遍历N的每一位上的数字,在相应的数组中自加 如果有一个数组元素等于2 说明至少有2个位上的数相同temp = m%10;for(int i=0 ;i<=9;i++){if(temp==i){num[i]++;if(num[i]==2){return 1;}}}m/=10;}return 0;}return 0;
}


  相关解决方案