c - 我的字符频率程序似乎有一个无限循环

标签 c loops infinite-loop

这是我对经典“C 编程语言”练习 1-14 的解决方案。它应该返回输入中字符的频率。它确实这样做了,但它一直打印完整的频率列表,直到编译器停止。我试图找到无限循环的根源。它在哪里?

#include <stdio.h>

char j;
int i;
int tally;
char input[100];
int k;

int main ()
{
for (k = 0; k < 100; k++)
{
    input[k] = getchar();
}

for (j = 0; j <= 127; j++)
{
    tally = 0;
    for (i = 0; i < 100; i++)
    {
        if (input[i] == j)
        { 
            tally++;
        }
    }
    if (tally != 0)
    {
        printf ("%c : %d times\n", j, tally);
    }
}
return 0;
}

最佳答案

问题出在你的变量 j 上,其类型为 char :

for (j = 0 ; j <= 127 ; j++)

char 的系统上有符号,最大值为char127 ,这意味着j <= 127条件始终为真。

尽管您可以通过声明 j 来解决此问题如unsigned char ,有一个更好的方法来计算字符:创建一个包含 128 个计数器的数组,然后遍历 input[]一次:

unsigned char input[100];
int tally[128] = {0};
for (int i = 0 ; i < 100 ; i++) {
    if (input[i] < 128) {
        tally[input[i]]++;
    }
}
for (int c = 0 ; c != 128 ; c++) {
    if (tally[c] != 0) {
        printf("%c : %d times\n", c, tally[c]);
    }
}

关于c - 我的字符频率程序似乎有一个无限循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51952757/

相关文章:

java - 即使满足条件,While 循环也不会终止-Java

c - __int64 用于 GCC 作为预处理器选项

java - 使用 hibernate 获取数据时无限循环

c - 为什么这个例子在C中陷入了无限循环?

php - php 数组最后一个元素的不同 css 样式

c++ - 在 C++ 中循环遍历一个数组

java - 带数据验证的文本框

c - 测试 “if (i && (i- 1))”是什么意思?

c - c 中的 fread() 和 strncpy() 中的空字符

纯 C 中的 Cocoa OpenGL 窗口?