90 选票统计

news/2025/2/25 18:54:42

90 选票统计

作者: Turbo时间限制: 1S章节: 结构体

问题描述 :

学生会主席投票选举工作正在举行。本次投票将采用电脑统计选票的方式,当投票选举正式开始后,同学们将排队一 一走到电脑前,投上自己神圣的一票:在电脑前输入一个姓名,然后输入回车表示确认。

投票结束后显示得票最高的同学姓名,该同学将当选为新一届学生会主席。

请编程统计投票。

输入说明 :

输入包含多行,每行是一个由英文字母组成的字符串,表示一个姓名,首尾以及中间都不包含空格。

参加投票学生的人数不超过100人,每个学生姓名字符串的长度小于20。

由于学生投票时输入的姓名有大写有小写,你在统计时不区分大小写,即"Liming"和"liming"是同一个人。

输出说明 :

输出为一个字符串——当选为学生会主席的学生姓名以及他的票数,中间用一个空格分隔。

输入保证没有两个人并列票数最高。

输出的英文字母全部用小写。

输入范例 :

limin
LIMING
liming
wangshan
huyou
LiMing
输出范例 :

liming 3

#不知道为啥本地跑就可以 OJ确不行 emmmm…好气哦
要是哪个大佬看到我的问题了,可以在下面评论,或者私信我
在这里插入图片描述

#include<stdio.h>
#include<string.h>
#include<memory.h>
#include<ctype.h>
struct candidate{
	char name[21];
	int poll;
};
int compare(char str1[],char str2[]);
int main(){
	struct candidate c[100];
	//初始化结构体数组 初试值为0
	memset(c,0,sizeof(char)*100);
	char str[21];
	int len,i,flag,max;
	while(gets(str)){
		//getchar();
		len=strlen(str);
		for(i=0;i<len;i++){
			if(isupper(str[i])){
				str[i]+=32;
			}
		}
		flag=0;
		for(i=0;i<100;i++){
			//查询结构体数组中如果有该名字,则票数加一
			if(compare(c[i].name,str)){
				c[i].poll++;
				flag=1;
			}
		}
		//如果没找到则新增
		if(!flag){
			//遍历结构体数组,在第一个票数为0的位置插入
			for(i=0;i<100;i++){
				if(c[i].poll==0){
					strcpy(c[i].name,str);
					c[i].poll++;
					break;
				}
			}
		}
	}
	//循环
	max=0;
	for(i=0;i<100;i++){
		if(c[max].poll<c[i].poll){
			max=i;
		}
	}
	printf("%s %d\n",c[max].name,c[max].poll);
	return 0;
}

int compare(char str1[],char str2[]){
	int len1,len2,i;
	len1=strlen(str1);
	len2=strlen(str2);
	if(len1!=len2){
		return 0;
	}
	for(i=0;i<len1;i++){
		if(str1[i]==str2[i]){
			continue;
		}else{
			return -1;
		}
	}
	return 1;
}

Input:
ling
Liming
LIMING
liming
wang
hu
本地结果
在这里插入图片描述
OJ结果
在这里插入图片描述


http://www.niftyadmin.cn/n/710567.html

相关文章

Java技术体系 JDK与JRE

从广义上讲&#xff0c;Clojure、JRuby、Groovy等运行于Java虚拟机上的语言及其相关的程序都属于Java技术体系中的一员。如果仅从传统意义上来看&#xff0c;Sun官方所定义的Java技术体系包括以下几个组成部分&#xff1a; •Java程序设计语言 •各种硬件平台上的Java虚拟…

redhat5.4 www服务器配置实例(1)

redhat5.4 www服务器配置实例 要求 主站点:www.abc.com ip:192.168.1.106 任何人可见 市场部:mkt.abc.com ip:192.168.1.106 禁止192.168.1.115查看,并且只允许用户 : code,anys,可见 技术部:tec.abc.com ip:192.168.1.106 全部的人使用https连接 实例…

LeetCode Minimum Depth of Binary Tree

Given a binary tree, find its minimum depth.The minimum depth is the number of nodes along the shortest path from the root node down to the nearest leaf node.思路分析:这题和Maximum Depth of Binary Tree相似&#xff0c;可是如今要返回最小深度&#xff0c;递归的…

大二上学期九月周总结报告二

这周我在慕课网上学习java的入门课程&#xff0c;重新回顾在暑假学习过的java的类的定义、对象的使用、静态和动态方法等&#xff0c;编写了一个简单的成绩信息管理系统&#xff0c; 并且安装好了mysql和配置好了环境。 下周继续学习java基础课程&#xff0c;学习建模语言基础知…

91 数星星

91 数星星 一闪一闪亮晶晶&#xff0c;漫天都是小星星挂在天上放光明&#xff0c;好像许多小眼睛 作者: Turbo时间限制: 1S章节: 结构体 问题描述 : 一天&#xff0c;小明坐在院子里数星星&#xff0c;爸爸就出了个难题给她&#xff1a;爸爸在天空指定了一个区域&#xff0…

学号:201621123032 《Java程序设计》第9周学习总结(

1&#xff1a;本周学习总结 1.1&#xff1a;以你喜欢的方式&#xff08;思维导图或其他&#xff09;归纳总结集合与泛型相关内容 2&#xff1a;书面作业 2.1&#xff1a; List中指定元素的删除(题集题目) 2.1.1&#xff1a;实验总结。并回答&#xff1a;列举至少2种在List中删除…

seci-log 1.03 日志分析软增加web日志分析

日志分析软件的升级了&#xff0c;我们在上次十种告警(非上班时间访问&#xff0c;非上班地点访问&#xff0c;密码猜测&#xff0c;账号猜测&#xff0c;账号猜测成功、敏感文件操作告警和高危命令操作&#xff0c;主机扫描&#xff0c;端口扫描&#xff0c;非法外联)的基础上…

92 按出生日期排序

92 按出生日期排序 作者: Turbo时间限制: 1S章节: 结构体 问题描述 : 小明希望将自己的通讯录按好友的生日顺序排序&#xff0c;这样查看起来方便多了&#xff0c;也避免错过好友的生日。 为了小明的美好愿望&#xff0c;你帮帮他吧。小明的好友信息包含姓名、出生日期。其…