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;
}
相关文章
|
2月前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
196 14
|
2月前
|
存储 编译器 C语言
【C语言】结构体详解 -《探索C语言的 “小宇宙” 》
结构体通过`struct`关键字定义。定义结构体时,需要指定结构体的名称以及结构体内部的成员变量。
208 10
|
3月前
|
机器学习/深度学习 算法 数据挖掘
C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出
本文探讨了C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出。文章还介绍了C语言在知名机器学习库中的作用,以及与Python等语言结合使用的案例,展望了其未来发展的挑战与机遇。
78 1
|
3月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
99 1
|
3月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
3月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
99 5
|
3月前
|
网络协议 物联网 数据处理
C语言在网络通信程序实现中的应用,介绍了网络通信的基本概念、C语言的特点及其在网络通信中的优势
本文探讨了C语言在网络通信程序实现中的应用,介绍了网络通信的基本概念、C语言的特点及其在网络通信中的优势。文章详细讲解了使用C语言实现网络通信程序的基本步骤,包括TCP和UDP通信程序的实现,并讨论了关键技术、优化方法及未来发展趋势,旨在帮助读者掌握C语言在网络通信中的应用技巧。
81 2
|
3月前
|
存储 数据建模 程序员
C 语言结构体 —— 数据封装的利器
C语言结构体是一种用户自定义的数据类型,用于将不同类型的数据组合在一起,形成一个整体。它支持数据封装,便于管理和传递复杂数据,是程序设计中的重要工具。
|
3月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
3月前
|
存储 NoSQL 编译器
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。

热门文章

最新文章