鱼C论坛

 找回密码
 立即注册
查看: 2941|回复: 1

[已解决]结构体作业,萌新求教

[复制链接]
发表于 2022-12-5 16:20:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
在选举中进行投票,包含候选人姓名、得票数,假设有多位候选人,用结构体数组统计各候选人的得票数。

输出格式:

"请输入候选人数量(大于3个):\n"

"请输入第%d个候选人姓名:\n"

"请输入投票人数量(大于10个):\n"

"第%d个候选人姓名:%s\n"

"请开始投票:\n"

"请第%d个投票人输入候选人姓名:\n”

"第%d个候选人:%s的票数为%d\n"

用例:3  王 李 张 6 王 王 王 李 李 张
输出结果:
请输入候选人数量(大于3个):
请输入第1个候选人姓名:
请输入第2个候选人姓名:
请输入第3个候选人姓名:
请输入投票人数量(大于10个):
第1个候选人姓名:王
第2个候选人姓名:李
第3个候选人姓名:张
请开始投票:
请第1个投票人输入候选人姓名:
请第2个投票人输入候选人姓名:
请第3个投票人输入候选人姓名:
请第4个投票人输入候选人姓名:
请第5个投票人输入候选人姓名:
请第6个投票人输入候选人姓名:
第1个候选人:王的票数为3
第2个候选人:李的票数为2
第3个候选人:张的票数为1



实在没有头绪,能写下这段代码吗
最佳答案
2022-12-5 17:29:56
本帖最后由 jhq999 于 2022-12-5 17:35 编辑
  1. #include <stdio.h>

  2. struct HXR
  3. {
  4.     union
  5.     {
  6.         long long nameval;
  7.         char name[8];
  8.     };
  9.     int count;
  10. };


  11. int main()
  12. {
  13.     int i,j, n,m;
  14.     scanf("%d",&n);
  15.     struct HXR hxr[n+1];
  16.     for(i=0;i<n;i+=1)
  17.     {
  18.         hxr[i].nameval=0;
  19.         hxr[i].count=0;
  20.         scanf("%s",hxr[i].name);
  21.     }
  22.     hxr[n].nameval=0;
  23.     hxr[n].count=0;
  24.     scanf("%d",&m);
  25.     for(i=0;i<m;i+=1)
  26.     {
  27.         hxr[n].nameval=0;
  28.         scanf("%s",hxr[n].name);
  29.         for(j=0;j<n;j+=1)
  30.         {
  31.             if(hxr[n].nameval==hxr[j].nameval)
  32.             {
  33.                 hxr[j].count+=1;
  34.                 break;
  35.             }
  36.         }
  37.     }
  38.     for(j=0;j<n;j+=1)
  39.     {
  40.         printf("%s:%d\n",hxr[j].name,hxr[j].count);
  41.     }
  42.     return 0;
  43. }
复制代码

  1. 3  王 李 张 6 王 王 王 李 李 张
  2. 王:3
  3. 李:2
  4. 张:1

  5. Process returned 0 (0x0)   execution time : 1.487 s
  6. Press any key to continue.
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-12-5 17:29:56 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jhq999 于 2022-12-5 17:35 编辑
  1. #include <stdio.h>

  2. struct HXR
  3. {
  4.     union
  5.     {
  6.         long long nameval;
  7.         char name[8];
  8.     };
  9.     int count;
  10. };


  11. int main()
  12. {
  13.     int i,j, n,m;
  14.     scanf("%d",&n);
  15.     struct HXR hxr[n+1];
  16.     for(i=0;i<n;i+=1)
  17.     {
  18.         hxr[i].nameval=0;
  19.         hxr[i].count=0;
  20.         scanf("%s",hxr[i].name);
  21.     }
  22.     hxr[n].nameval=0;
  23.     hxr[n].count=0;
  24.     scanf("%d",&m);
  25.     for(i=0;i<m;i+=1)
  26.     {
  27.         hxr[n].nameval=0;
  28.         scanf("%s",hxr[n].name);
  29.         for(j=0;j<n;j+=1)
  30.         {
  31.             if(hxr[n].nameval==hxr[j].nameval)
  32.             {
  33.                 hxr[j].count+=1;
  34.                 break;
  35.             }
  36.         }
  37.     }
  38.     for(j=0;j<n;j+=1)
  39.     {
  40.         printf("%s:%d\n",hxr[j].name,hxr[j].count);
  41.     }
  42.     return 0;
  43. }
复制代码

  1. 3  王 李 张 6 王 王 王 李 李 张
  2. 王:3
  3. 李:2
  4. 张:1

  5. Process returned 0 (0x0)   execution time : 1.487 s
  6. Press any key to continue.
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 0 反对 1

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-14 00:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表