不用bool函数c语言 求1-n之间能被3整除且至少有一位数字是5的所有正整数的个数
时间: 2024-09-07 20:05:33 浏览: 55
在C语言中,不使用bool函数求解1-n之间能被3整除且至少有一位数字是5的所有正整数的个数,可以通过编写一个函数来实现。这里提供一个可能的解决方案,该方案使用了循环和条件判断来找出满足条件的数字,并计数。
首先,需要一个函数来判断一个数是否包含数字5,可以通过检查每个数位来实现。然后,通过一个循环遍历1到n之间的所有数字,对于每个数字,先判断它是否能被3整除,然后使用前面提到的函数检查数字中是否包含5。如果一个数字同时满足这两个条件,就将计数器加一。
以下是具体的C语言代码实现:
```c
#include <stdio.h>
// 判断数字是否包含数字5的函数
int containsFive(int num) {
while (num > 0) {
if (num % 10 == 5) {
return 1; // 如果数字包含5,则返回1
}
num /= 10; // 去掉数字的最后一位
}
return 0; // 如果数字不包含5,则返回0
}
// 求解1-n之间能被3整除且至少有一位数字是5的所有正整数的个数的函数
int countNumbers(int n) {
int count = 0; // 计数器初始化为0
for (int i = 1; i <= n; ++i) {
// 判断数字是否能被3整除且是否包含数字5
if (i % 3 == 0 && containsFive(i)) {
count++; // 如果满足条件,计数器加1
}
}
return count; // 返回计数结果
}
int main() {
int n;
printf("请输入n的值:");
scanf("%d", &n);
int result = countNumbers(n);
printf("满足条件的正整数个数是:%d\n", result);
return 0;
}
```
这段代码中定义了两个函数:`containsFive`用于判断一个数是否包含数字5,`countNumbers`用于计算满足条件的正整数个数。在`main`函数中,用户输入n的值,程序计算并输出结果。
阅读全文