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

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

本文关键字:C++ 数组 计算      更新时间:2023-10-16

我有一个任务,我有一个数组,假设 {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。

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

在代码中,您没有打印正确的值,并且代码不足以打印出所需的输出。您应该决定在循环外打印输出,如果要计算到最大和最小出现时间,则应再添加一个 if 语句以检查何时 max == tab[i] 和 min = tab[i]。如果你在 if (tab[i]> max) 和 if (tab[i]

希望这有帮助。