C++计算一个值在数组中出现的次数

Counting how many time a value appeared in array in C++

我有一个任务,其中有一个数组,比方说 {2, 3, 4, 5, 2, 2, 3, 5, 5, 5} 并且只使用一个循环我必须找到最小值和最大值。这个我已经有了。我还必须计算(在同一个循环中)这个最小值和最大值出现了多少次。我有那个问题。我只能使用一个循环! 输出应该是这样的: 最少:2 出现:3 次 最多:5次出现:4次

代码:

int size = sizeof(tab) / sizeof(int);
int max = tab[0];
int min = tab[0];
int minCounter = 1;
int maxCounter = 1;

for (int i = 0; i < size; i++) {
    cout << "Tab[" << i+1 << "]: " << tab[i] << endl;
    if (tab[i] > max) {
        max = tab[i];
        maxCounter++;
    }
    if (tab[i] < min) {
        min = tab[i];
        minCounter++;
    }
}

维护一个 max_count 变量,每次遇到新的最大值时将其重置为 1。

(解决方案的其余部分作为练习留给 reader...)

在您的代码中,您没有打印正确的值,并且代码不足以打印出所需的输出。你应该决定在循环外打印输出,如果你想计算最大和最小出现时间,你应该再添加一个 if 语句来检查何时 max == tab[i] 和 min = tab[i]。如果您在 if (tab[i] > max) 和 if (tab[i] < min) 之后执行此操作,则无需将 minCounter 和 maxCounter 初始化为 1,否则它们需要初始化为 1.

希望对您有所帮助。