c语言输入一个数n,统计从1到n这n个数中,每个数字0到9出现的次数
时间: 2024-05-03 09:21:31 浏览: 80
```
#include <stdio.h>
int main() {
int n, digit_count[10] = {0}; // 初始化为0
printf("请输入一个数n:");
scanf("%d", &n);
// 统计每个数字出现的次数
for (int i = 1; i <= n; i++) {
int num = i;
while (num) {
int digit = num % 10;
digit_count[digit]++;
num /= 10;
}
}
// 输出结果
printf("从1到%d这%d个数中,每个数字出现的次数为:\n", n, n);
for (int i = 0; i < 10; i++) {
printf("%d出现了%d次\n", i, digit_count[i]);
}
return 0;
}
```
样例输入:
```
请输入一个数n:100
```
样例输出:
```
从1到100这100个数中,每个数字出现的次数为:
0出现了11次
1出现了21次
2出现了20次
3出现了20次
4出现了20次
5出现了20次
6出现了20次
7出现了20次
8出现了20次
9出现了20次
```
相关问题
c语言输入一个数n,统计从1到n这n个数中,每个数字0到9出现的次数,输出次数最多的那个数字,如果次数相同,则输出值最大的那个
数字。
```c
#include <stdio.h>
int main() {
int n, count[10] = {0}; // count数组记录0~9出现的次数,初始值为0
scanf("%d", &n);
int i;
for (i = 1; i <= n; i++) {
int num = i;
while (num > 0) {
int digit = num % 10;
count[digit]++;
num /= 10;
}
}
int max_count = count[0], max_digit = 0;
for (i = 1; i < 10; i++) {
if (count[i] > max_count) {
max_count = count[i];
max_digit = i;
} else if (count[i] == max_count && i > max_digit) {
max_digit = i;
}
}
printf("%d\n", max_digit); // 输出出现次数最多且值最大的数字
return 0;
}
```
上述代码中,count数组用于记录0~9出现的次数。在for循环中,将1到n的每个数的每一位取出来,然后在count数组中累加对应数字的出现次数。最后再遍历一遍count数组,找出出现次数最多且值最大的数字即可。
用c语言输入n个数字,统计最大数字出现次数 当你有n个数字,并想要统计其中的最大数字出现的
在C语言中,你可以使用数组存储这些数字,同时维护两个变量:一个用于存储当前找到的最大值,另一个用于记录该最大值出现的次数。这里是一个简单的步骤示例:
1. 首先,创建一个足够大的数组来存储n个整数,比如`int numbers[n]`。
2. 使用循环从用户那里获取输入,直到输入负数为止,将每个输入的数字存储到数组中。
3. 初始化最大值为数组的第一个元素,出现次数为1。
4. 遍历数组,如果遇到比当前最大值更大的数,则更新最大值并重置出现次数为1;如果遇到相等的数,则增加出现次数。
5. 循环结束后,最大值就是最大的那个数,出现次数就是它在数组中出现的总次数。
下面是伪代码形式的实现:
```c
#include <stdio.h>
void countMax(int arr[], int n) {
int max = arr[0];
int maxCount = 1;
for (int i = 1; i < n; i++) {
int input;
scanf("%d", &input);
if (input > max) {
max = input;
maxCount = 1;
} else if (input == max) {
maxCount++;
}
}
printf("最大数字 %d 出现了 %d 次\n", max, maxCount);
}
int main() {
int n;
printf("请输入数字的数量(n): ");
scanf("%d", &n);
// 假设我们已经验证了输入的有效性
int numbers[n];
for (int i = 0; i < n; i++) {
scanf("%d", &numbers[i]);
}
countMax(numbers, n);
return 0;
}
```
阅读全文