当前位置: 首页 > news >正文

水作业.2

用程序模拟一个活动的投票统计功能。首先输入参选人员个数,再输入每位参选人员名字(不超过20字节),再输入选票张数,再依次输入选票中所选的参选人名(选票中必须选参选中的其中一位)。在输入选票过程中统计每位参选人的得票数,最终按得票数由高到低的顺序输出参选人和其票数(空格分隔),如果票数相同,则按名字从小到大的顺序(ASCII码顺序)输出。
提示:选票信息按如下结构定义:

struct vote { char name[20];//名字 int count;//票数 };

输入样例:

3 Li Wang Zhang 8 Li Wang Li Zhang Li Li Wang Zhang

输出样例:

Li 4 Wang 2 Zhang 2

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

struct vote {
char name[20];
int count = 0; // 直接初始化为0
};

int main() {
int n, m;
cin >> n;

vote candidates[100];

// 输入候选人
for (int i = 0; i < n; i++) {
cin >> candidates[i].name;
}

cin >> m;

// 统计选票
for (int i = 0; i < m; i++) {
char name[20];
cin >> name;

// 查找这个人
for (int j = 0; j < n; j++) {
if (strcmp(candidates[j].name, name) == 0) {
candidates[j].count++;
break;
}
}
}

// 简单排序(冒泡排序)
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - 1 - i; j++) {
// 先比较票数
if (candidates[j].count < candidates[j + 1].count) {
// 交换两个候选人
vote temp = candidates[j];
candidates[j] = candidates[j + 1];
candidates[j + 1] = temp;
}
// 如果票数相同,比较名字
else if (candidates[j].count == candidates[j + 1].count) {
if (strcmp(candidates[j].name, candidates[j + 1].name) > 0) {
vote temp = candidates[j];
candidates[j] = candidates[j + 1];
candidates[j + 1] = temp;
}
}
}
}

// 输出结果
for (int i = 0; i < n; i++) {
cout << candidates[i].name << " " << candidates[i].count << endl;
}

return 0;
}

http://www.jsqmd.com/news/120604/

相关文章:

  • LangSmith 自动追踪 (Tracing) 实战指南
  • 基于Spring Boot的流浪动物救助平台的设计与实现毕业设计
  • 3.2
  • AOP技术
  • 如何更好地作为数据科学家进行沟通
  • 项目审批管理系统测评:6款助力流程化审批与规范化管理的实用方案
  • DM数据库安装与配置指南
  • vim 十六进制显示模式
  • java中<clinit>()与<init>()区别
  • 3.1
  • 施工项目管理系统有哪些:10款支持进度、成本与质量全流程管控的工具
  • 多项目管理系统怎么选:8款支持跨项目资源与进度统筹的解决方案
  • 优化程序性能:JVM 会对final变量进行优化(如编译期常量折叠,直接将常量值嵌入字节码中,避免运行时获取);具体含义
  • 142_尚硅谷_数组的使用价值
  • 数字化项目管理系统分享:7款助力企业实现项目智能化协同的工具精选
  • 3.3
  • 财务目标页面 UI 与进度展示 - Cordova与OpenHarmony混合开发实战
  • 基于Spring Boot的美食信息分享平台设计与实现毕设源码
  • 2025年主流项目集管理系统工具推荐:6款助力企业实现战略级项目群管控的系统盘点
  • 基于Spring Boot的稀有植物保护平台开发毕设源码
  • 3.4
  • CordovaOpenHarmony使用指南文档
  • 配置Wireshark抓取https数据包
  • C#应用程序取得当前目录和退出
  • CF1088E Ehab and a component choosing problem
  • 【文章记录-001】
  • 9.37万亿元与9.58亿用户:拆解2025上半年中国数字消费的增长引擎
  • 如何在 Power BI 中基于多个列应用 RLS
  • 报表生成功能Cordova与OpenHarmony混合开发实战
  • 3.7