杭电acm题库 1001 统计气球问题

本代码用C++的string类型直接创建一个字符串数组,额外创建一个count数组用来计数。

主要想法是采用两两比较的方法比较两个字符串是否相等,如果相等的话则count[i]++。两个循环都是从0开始,包含一次字符串的自我比较,让count为1。

 

#include <iostream>
#include <string>
using namespace std;


int main(){
	
	string color[1001];
	int count[1001];
	int flag=0;
	int max=0;
	int n;
	
	
	while(scanf("%d", &n)!=EOF){
		if (n==0)
			break;
			
		for(int i=0; i<n; i++){
			count[i]=0;
		}
			
		for(int i=0; i<n; i++){
			cin >> color[i];
		}
		
		for (int i=0; i<n; i++){
			for (int j=0; j<n; j++){
				if (color[i]==color[j])
					count[i]+=1;
			}
		}

		max = 0;
		for(int i=0; i<n; i++){
		if (count[i] > max){
			max = count[i];
			flag = i;
		}
	}
	
	cout << color[flag] << endl;
	}
	

    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值