判断满足条件的三位数:编写一个函数,利用参数传入一个3位数n, 找出 101~n 间所有满足下列两个条件的数:它是完全平方数,又有两位数字相同,如 144、676 等,函 数返回找出这样的数据的个数。试用c语言编写相应程序。
时间: 2024-03-19 18:44:37 浏览: 212
好的,我会尽力回答你的问题。以下是一个满足你要求的C语言函数:
```c
int findNumbers(int n) {
int count = 0;
for (int i = 101; i <= n; i++) {
int a = i / 100; // 百位数
int b = (i / 10) % 10; // 十位数
int c = i % 10; // 个位数
if (a == b || b == c || a == c) { // 判断是否有两位数字相同
int squareRoot = sqrt(i);
if (squareRoot * squareRoot == i) { // 判断是否是完全平方数
count++;
}
}
}
return count;
}
```
这个函数的思路是先通过循环枚举101到n之间的所有三位数,然后通过除法和取模运算得到这个数的百位数、十位数和个位数。接着,判断这个数是否有两位数字相同,如果有则再判断它是否是完全平方数。如果满足条件,则累计计数器的值。最后,返回找到的满足条件的数据的个数。
调用这个函数的方法如下:
```c
int count = findNumbers(500);
printf("找到的满足条件的数据的个数为:%d\n", count);
```
这里以500为例,调用函数后会输出在101到500之间找到的满足条件的数据的个数。
阅读全文