#include <stdio.h>
#include <string.h>
struct Student
{
int num;
char name[32];
char sex[32];
int age;
double score;
char addr[32];
};
int main()
{
//int arr[] = {1,2,3};
int i;
struct Student arr2[3] = {
{2,"小王","男",22,99,"上海"},
{3,"张三","男",20,77,"北京"},
{4,"李四","女",18,66,"西安"}
};
int len = sizeof(arr2)/sizeof(arr2[0]);
for(i = 0;i < len;i++){
printf("学号:%d, 年龄:%d, 分数:%.2f, 姓名:%s, 性别:%s, 地址:%s\n",
arr2[i].num,arr2[i].age,arr2[i].score,arr2[i].name,arr2[i].sex,arr2[i].addr);
}
return 0;
}
结构体数组应用–选票系统
#include <stdio.h>
#include <string.h>
struct XuanMin
{
char name[32];
int tickets;
};
int main()
{
int i,j,mark = 0;
int feipiao = 0;
int total = 5;//票数为5
char tmpname[32];
struct XuanMin xm[3] = {};//选民有3个
struct XuanMin max;
int len = sizeof(xm)/sizeof(xm[0]);
//初始化选民信息
for(i = 0;i < len;i++){
xm[i].tickets = 0; //初始化选票为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)); //清零
/*memset:作用是在一段内存块中填充某个给定的值,
它是对较大的结构体或数组进行清零操作的一种最快方法 。
*/
scanf("%s",tmpname);
for(j = 0;j < len;j++){
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];
for(i = 0;i < len;i++){
if(max.tickets < xm[i].tickets){
max = xm[i];
}
}
printf("%s以%d票当选!\n 废票是:%d",max.name,max.tickets,feipiao);
return 0;
}