鱼C论坛

 找回密码
 立即注册
查看: 2711|回复: 3

[已解决]结构体问题,萌新求助

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

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

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

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-6 11:58:53
本帖最后由 jhq999 于 2022-12-6 11:59 编辑
sususususu 发表于 2022-12-5 23:04
额,我刚学结构体,这个问题搞得我无从下手,所以想看看答案,参考学习下。夸张点说,就是完全不会,请大 ...

你不会输入输出都不会吧?
#include <stdio.h>
/*
用例:3  王 李 张 6 王 王 王 李 李 张
输出结果:
请输入候选人数量(大于3个):
请输入第1个候选人姓名:
请输入第2个候选人姓名:
请输入第3个候选人姓名:
请输入投票人数量(大于10个):
第1个候选人姓名:王
第2个候选人姓名:李
第3个候选人姓名:张
请开始投票:
请第1个投票人输入候选人姓名:
请第2个投票人输入候选人姓名:
请第3个投票人输入候选人姓名:
请第4个投票人输入候选人姓名:
请第5个投票人输入候选人姓名:
请第6个投票人输入候选人姓名:
第1个候选人:王的票数为3
第2个候选人:李的票数为2
第3个候选人:张的票数为1
*/


struct HXR
{
    union
    {
        long long nameval;
        char name[8];
    };
    int count;
};


int main()
{
    int i,j, n,m;
    printf("请输入候选人数量(大于3个):");
    scanf("%d",&n);
    struct HXR hxr[n+1];
    for(i=0;i<n;i+=1)
    {
        printf("请输入第%d个候选人姓名:",i+1);
        hxr[i].nameval=0;
        hxr[i].count=0;
        scanf("%s",hxr[i].name);
    }
    hxr[n].nameval=0;
    hxr[n].count=0;
    printf("请输入投票人数量(大于10个):");
    scanf("%d",&m);
    printf("请开始投票:\n");
    for(i=0;i<m;i+=1)
    {
        hxr[n].nameval=0;
        printf("请第%d个投票人输入候选人姓名:",i+1);
        scanf("%s",hxr[n].name);
        for(j=0;j<n;j+=1)
        {
            if(hxr[n].nameval==hxr[j].nameval)
            {
                hxr[j].count+=1;
                break;
            }
        }
    }
    for(j=0;j<n;j+=1)
    {
        printf("第%d个候选人:%s的票数为:%d\n",j+1,hxr[j].name,hxr[j].count);
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-12-5 22:26:34 | 显示全部楼层
好歹问的问题具体一些吧,比如碰到哪些问题了,遇到哪些问题了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-5 23:04:00 | 显示全部楼层
Hello110 发表于 2022-12-5 22:26
好歹问的问题具体一些吧,比如碰到哪些问题了,遇到哪些问题了

额,我刚学结构体,这个问题搞得我无从下手,所以想看看答案,参考学习下。夸张点说,就是完全不会,请大佬伸出援手,写一个程序能表达出上述的用例
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-6 11:58:53 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jhq999 于 2022-12-6 11:59 编辑
sususususu 发表于 2022-12-5 23:04
额,我刚学结构体,这个问题搞得我无从下手,所以想看看答案,参考学习下。夸张点说,就是完全不会,请大 ...

你不会输入输出都不会吧?
#include <stdio.h>
/*
用例:3  王 李 张 6 王 王 王 李 李 张
输出结果:
请输入候选人数量(大于3个):
请输入第1个候选人姓名:
请输入第2个候选人姓名:
请输入第3个候选人姓名:
请输入投票人数量(大于10个):
第1个候选人姓名:王
第2个候选人姓名:李
第3个候选人姓名:张
请开始投票:
请第1个投票人输入候选人姓名:
请第2个投票人输入候选人姓名:
请第3个投票人输入候选人姓名:
请第4个投票人输入候选人姓名:
请第5个投票人输入候选人姓名:
请第6个投票人输入候选人姓名:
第1个候选人:王的票数为3
第2个候选人:李的票数为2
第3个候选人:张的票数为1
*/


struct HXR
{
    union
    {
        long long nameval;
        char name[8];
    };
    int count;
};


int main()
{
    int i,j, n,m;
    printf("请输入候选人数量(大于3个):");
    scanf("%d",&n);
    struct HXR hxr[n+1];
    for(i=0;i<n;i+=1)
    {
        printf("请输入第%d个候选人姓名:",i+1);
        hxr[i].nameval=0;
        hxr[i].count=0;
        scanf("%s",hxr[i].name);
    }
    hxr[n].nameval=0;
    hxr[n].count=0;
    printf("请输入投票人数量(大于10个):");
    scanf("%d",&m);
    printf("请开始投票:\n");
    for(i=0;i<m;i+=1)
    {
        hxr[n].nameval=0;
        printf("请第%d个投票人输入候选人姓名:",i+1);
        scanf("%s",hxr[n].name);
        for(j=0;j<n;j+=1)
        {
            if(hxr[n].nameval==hxr[j].nameval)
            {
                hxr[j].count+=1;
                break;
            }
        }
    }
    for(j=0;j<n;j+=1)
    {
        printf("第%d个候选人:%s的票数为:%d\n",j+1,hxr[j].name,hxr[j].count);
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-26 09:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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