C语言使用结构体模拟选举的小应用

简介: C语言使用结构体模拟选举的小应用

C语言结构体的模拟选举小应用

  • 现在有三个被选举人,五个投票人
  • 最后以票高者获胜

小应用中用到了C语言中的结构体作为主要编写主体

上代码

#include <stdio.h>
#include <string.h>
struct XuanMin
{
  char name[32];
  int tickets;
};
int main()
{
  struct XuanMin xm[3];
  struct XuanMin max;
  struct XuanMin max1;
  int feiPiao = 0;
  int i;
  int len;
  int j;
  int mark = 0;
  int total = 5;
  char tmpName[32];
  //初始化选民信息
  len = sizeof(xm)/sizeof(xm[0]);
  for(i = 0; i<len; i++){
    xm[i].tickets = 0;
    printf("请输入第%d个选民的名字:\n",i+1);
    scanf("%s",xm[i].name);
  }
  //唱票环节
  for(i=0;i<5;i++){
    mark = 0;
    printf("请输入你投给谁:\n");
    memset(tmpName,'\0',sizeof(tmpName)); //每次清空一下
    scanf("%s",tmpName);//输入选中的选民名字,像拆开一个选票,看到名字一样
    for(j = 0;j<len; j++){ //拿到名字,对应候选人票数加1
      if(strcmp(tmpName, xm[j].name) == 0){
        xm[j].tickets++;
        mark  = 1;
      }
    }
    if(mark == 0){
      printf("没有此候选人,放弃\n");
      feiPiao++;
    }
  }
  //公布结果
  for(i=0;i<len;i++){
    printf("名字:%s,票数:%d\n",xm[i].name,xm[i].tickets);
  }
  max = xm[0];
  max1 = xm[0];
  for(i=1;i<len;i++){
    if(max.tickets < xm[i].tickets)
    {
      max = xm[i];
    }
    if(max.tickets == xm[i].tickets)
    {
            max1 = xm[i];
    }
  }
  if((strcmp(max.name,max1.name)!=0)&&(max.tickets == max1.tickets))//有种情况就是相同票数的被选举人的情况分开公布
  {
    printf("%s和%s以%d票同时当选!!废票是%d\n",max.name,max1.name,max1.tickets,feiPiao);
  }
  else{
    printf("%s以%d票当选!!废票是%d\n",max.name,max.tickets,feiPiao);
  }
  return 0;
}

结果如下:

最高票数的情况

f5c3504a4b174380a372bfe52b3ece93.png

相同票数的情况

151126f765e74973a6b2bf7fe3716a7e.png

证实了票高者获胜的事实

还有一种写法

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
struct XuanMin
{
  char name[32];
  int tickets;
};
struct XuanMin* initXms(struct XuanMin *p,int *pn)
{
  int i;
  if(p == NULL){
    printf("请输入有几个人参选:\n");
    scanf("%d",pn);
    p = (struct XuanMin*)malloc(*pn*sizeof(struct XuanMin));
  }
  for(i=0;i<*pn;i++){
    p->tickets = 0;
    printf("请输入第%d个选民的名字:\n",i+1);
    scanf("%s",p->name);
    p++;
  }
  return p-*pn;
}
void printXms(struct XuanMin *p,int len)
{
  int i;
  for(i=0;i<len;i++){
    printf("名字:%s,票数:%d\n",p->name,p->tickets);
    p++;
  }
}
int doVot(struct XuanMin *p, int len)
{
  int i;
  int j;
  int feiPiao = 0;
  int mark;
  char tmpName[32];
  struct XuanMin *pbak = p;
  for(i=0;i<5;i++){
    mark = 0;
    printf("请输入你投给谁:\n");
    memset(tmpName,'\0',sizeof(tmpName)); //每次清空一下
    scanf("%s",tmpName);//输入选中的选民名字,像拆开一个选票,看到名字一样
    p = pbak;
    for(j = 0;j<len; j++){ //拿到名字,对应候选人票数加1
      if(strcmp(tmpName, p->name) == 0){
        p->tickets++;
        mark  = 1;  
      }
      p++;
    }
    if(mark == 0){
      printf("没有此候选人,放弃\n");
      feiPiao++;
    }
  }
  return feiPiao;
}
struct XuanMin* getMax(struct XuanMin *p, int len)
{
  struct XuanMin* max;
  int i;
  max = p;
  for(i=0;i<len;i++){
    if(max->tickets < p->tickets){
      max = p;
    }
    p++;
  }
  return max;
}
int main()
{
  struct XuanMin *xm = NULL;
  struct XuanMin *final;
  int total = 0;
  xm = initXms(xm,&total);
  printXms(xm,total);
  int feip = doVot(xm,total);
  printf("废票数是:%d\n",feip);
  printXms(xm,total);
  final = getMax(xm,total);
  printf("%s以%d票当选!!废票是%d\n",max->name,final->tickets,feip);
  return 0;
}

更高深的写法

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
struct XuanMin
{
  char name[32];
  int tickets;
};
void initXms(struct XuanMin **pxm,int *pt)
{
  int i;
  //*pt = 0;
  //*pxm = NULL;
  if(*pxm == NULL){
    printf("请输入有几个人参选:\n");
    scanf("%d",pt);
    printf("一共%d个人参选\n",*pt);
    *pxm = (struct XuanMin*)malloc(*pt * sizeof(struct XuanMin));
  }
  for(i=0;i<*pt;i++){
    (*pxm)->tickets == 0;
    printf("请输入第%d个选民的名字:\n",i+1);
    scanf("%s",(*pxm)->name);
    (*pxm)++;
  }
  *pxm = *pxm - *pt;
}
void printXms(struct XuanMin *p,int len)
{
  int i;
  for(i=0;i<len;i++){
    printf("名字:%s,票数:%d\n",p->name,p->tickets);
    p++;
  }
}
int doVot(struct XuanMin *p, int len)
{
  int i;
  int j;
  int feiPiao = 0;
  int mark;
  char tmpName[32];
  struct XuanMin *pbak = p;
  for(i=0;i<5;i++){
    mark = 0;
    printf("请输入你投给谁:\n");
    memset(tmpName,'\0',sizeof(tmpName)); //每次清空一下
    scanf("%s",tmpName);//输入选中的选民名字,像拆开一个选票,看到名字一样
    p = pbak;
    for(j = 0;j<len; j++){ //拿到名字,对应候选人票数加1
      if(strcmp(tmpName, p->name) == 0){
        p->tickets++;
        mark  = 1;  
      }
      p++;
    }
    if(mark == 0){
      printf("没有此候选人,放弃\n");
      feiPiao++;
    }
  }
  return feiPiao;
}
struct XuanMin* getMax(struct XuanMin *p, int len)
{
  struct XuanMin* max;
  int i;
  max = p;
  for(i=0;i<len;i++){
    if(max->tickets < p->tickets){
      max = p;
    }
    p++;
  }
  return max;
}
int main()
{
  struct XuanMin *xm = NULL;
  struct XuanMin *final;
  int total = 0;
  initXms(&xm,&total);
  printXms(xm,total);
  int feip = doVot(xm,total);
  printf("废票数是:%d\n",feip);
  printXms(xm,total);
  final = getMax(xm,total);
  printf("%s以%d票当选!!废票是%d\n",final->name,final->tickets,feip);
  return 0;
}
相关文章
|
16天前
|
存储 算法 C语言
通义灵码在考研C语言和数据结构中的应用实践 1-5
通义灵码在考研C语言和数据结构中的应用实践,体验通义灵码的强大思路。《趣学C语言和数据结构100例》精选了五个经典问题及其解决方案,包括求最大公约数和最小公倍数、统计字符类型、求特殊数列和、计算阶乘和双阶乘、以及求斐波那契数列的前20项和。通过这些实例,帮助读者掌握C语言的基本语法和常用算法,提升编程能力。
|
10天前
|
存储 C语言
如何在 C 语言中实现结构体的深拷贝
在C语言中实现结构体的深拷贝,需要手动分配内存并逐个复制成员变量,确保新结构体与原结构体完全独立,避免浅拷贝导致的数据共享问题。具体方法包括使用 `malloc` 分配内存和 `memcpy` 或手动赋值。
23 10
|
9天前
|
存储 大数据 编译器
C语言:结构体对齐规则
C语言中,结构体对齐规则是指编译器为了提高数据访问效率,会根据成员变量的类型对结构体中的成员进行内存对齐。通常遵循编译器默认的对齐方式或使用特定的对齐指令来优化结构体布局,以减少内存浪费并提升性能。
|
14天前
|
编译器 C语言
共用体和结构体在 C 语言中的优先级是怎样的
在C语言中,共用体(union)和结构体(struct)的优先级相同,它们都是用户自定义的数据类型,用于组合不同类型的数据。但是,共用体中的所有成员共享同一段内存,而结构体中的成员各自占用独立的内存空间。
|
14天前
|
存储 C语言
C语言:结构体与共用体的区别
C语言中,结构体(struct)和共用体(union)都用于组合不同类型的数据,但使用方式不同。结构体为每个成员分配独立的内存空间,而共用体的所有成员共享同一段内存,节省空间但需谨慎使用。
|
18天前
|
编译器 C语言 C++
C语言结构体
C语言结构体
21 5
|
19天前
|
编译器 Linux C语言
C语言 之 结构体超详细总结
C语言 之 结构体超详细总结
13 0
|
24天前
|
存储 编译器 Linux
深入C语言:探索结构体的奥秘
深入C语言:探索结构体的奥秘
|
24天前
|
存储 编译器 C语言
c语言回顾-结构体(2)(下)
c语言回顾-结构体(2)(下)
28 0
|
24天前
|
存储 编译器 程序员
c语言回顾-结构体(2)(上)
c语言回顾-结构体(2)(上)
26 0