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