用C语言编程求出10000以内的所有符合如下条件的数:其高位数字小于低位数字。
时间: 2024-09-30 09:08:25 浏览: 67
在C语言中,你可以通过遍历10000以内的所有整数,并检查每一位是否满足高位数字小于低位数字的条件来实现这个功能。这里是一个简单的示例代码:
```c
#include <stdio.h>
int is_descending(int num) {
int digits[4]; // 假设最多4位数
int len = 0;
// 将数字转换为数组形式,便于比较
while (num != 0) {
digits[len] = num % 10; // 取余得到当前位
num /= 10; // 移除最低位
len++;
}
// 检查从最高位到最低位,如果任一位置违反规则则返回0
for (int i = 0; i < len - 1; i++) {
if (digits[i] >= digits[i + 1]) {
return 0; // 高位大于等于低位,不符合条件
}
}
return 1; // 全部符合条件,返回1
}
int main() {
int count = 0;
for (int i = 1; i <= 10000; i++) {
if (is_descending(i)) {
printf("%d ", i);
count++;
}
}
printf("\nNumber of descending numbers found: %d\n", count);
return 0;
}
```
这段代码首先定义了一个函数`is_descending`用于判断给定的数是否符合条件,然后在主函数中从1遍历到10000,对每个数调用该函数,如果是符合条件的就打印出来并增加计数。
阅读全文