[C++] 69387-n个数里出现次数大于等于 n/2 的数

博客围绕查找数组中出现次数大于等于数组长度一半的数展开。给出两种思路,思路一是排序后找中间数,但非最优解;思路二则通过特定变量记录和遍历数组来找出该数,还给出了对应代码实现,并附上相关链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


例题描述

输入n个整数,输出出现次数大于等于数组长度一半的数。

  • 输入描述:
    每个测试输入包含n个空格分割的n个整数,n不超过100,其中有一个整数出现次数大于等于n/2
  • 输出描述:
    输出出现次数大于等于n/2的数。

示例1:

  • 输入
    3 9 3 2 5 6 7 3 2 3 3 3
  • 输出
    3

思路一

最简单的思路就是排序,然后找中间那个数。但它不是最优的解法。

代码实现

#include <iostream>
#include <vector>
using namespace std;
int main(){
    int n;
    vector<int> v;
    while(cin >> n){
        v.push_back(n);
    }
    
    std::sort(v.begin(),v.end());
    
    cout << v[(v.size()/2)-1];
    return 0;
}

思路二

O(n)思想:
因为要找过半的数,用一个变量count记录读取每个变量变化的次数,一个变量temp记录可能过半的数。
先让count = 1,然后让temp = vec[0],然后往后遍历一遍。
碰到和temp相同的数就给count++,否则就count--,如果count变成0,就让temp=vec[i] (v数组遍历过程中的当前值),并让count = 1
如此遍历一遍,因为有一个数过半,所以temp最后肯定存储的是过半的数。

代码实现

#include <vector>
#include <iostream>
using namespace std;
int main(){
	int n;
	vector <int> v;
	while(cin >> n){
		v.push_back(n);
	}
	int count = 1;
	int temp = v[0];
	for(int i = 1; i < v.size(); ++i){
		if(v[i] == temp)
			count++;
		else
			count--;
		if(count == 0){
			temp = v[i];
			count++;
		}
	}
	cout << temp << endl;
	return 0;
}

链接:https://www.nowcoder.com/practice/eac8c671a0c345b38aa0c07aba40097b?tpId=85&&tqId=29866&rp=1&ru=/activity/oj&qru=/ta/2017test/question-ranking

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

giturtle

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值