标签:nio std text 变量共享 区别 一起 体会 spl ret
【实验结论】
Part1: 结构体类型及编程应用
• 程序源码ex1_2.cpp
1 #include <stdio.h> 2 3 const int N=5; 4 5 // 定义结构体类型struct student,并定义STU为其别名 6 typedef struct student { 7 long no; 8 char name[20]; 9 int score; 10 }STU; 11 12 // 函数声明 13 void input(STU s[], int n); 14 int findMinlist(STU s[], STU t[], int n); 15 void output(STU s[], int n); 16 17 int main() { 18 STU stu[N], minlist[N]; 19 int count; 20 21 printf("录入%d个学生信息\n", N); 22 input(stu, N); 23 24 printf("\n统计最低分人数和学生信息...\n"); 25 count = findMinlist(stu, minlist, N); 26 27 printf("\n一共有%d个最低分,信息如下:\n", count); 28 output(minlist, count); 29 30 return 0; 31 } 32 33 // 输入n个学生信息,存放在结构体数组s中 34 void input(STU s[], int n) { 35 int i; 36 for(i=0; i<n; i++) 37 scanf("%ld %s %d", &s[i].no, s[i].name, &s[i].score); 38 } 39 40 // 输出结构体s中n个元素信息 41 void output(STU s[], int n) { 42 int i; 43 for(i=0; i<n; i++) 44 printf("%ld %s %d\n", s[i].no, s[i].name, s[i].score); 45 } 46 47 int findMinlist(STU s[], STU t[], int n) { 48 int i,k=0,min; 49 min=s[0].score; 50 for(i=1;i<n;i++) 51 if(s[i].score<min) 52 min=s[i].score; 53 for(i=0;i<n;i++) 54 if(s[i].score==min) 55 t[k++]=s[i]; 56 return k; 57 }
• 运行结果截图
• 程序源码ex1_3.cpp
1 #include <stdio.h> 2 #include <string.h> 3 const int N = 10; 4 5 // 定义结构体类型struct student,并定义其别名为STU 6 typedef struct student { 7 long int id; 8 char name[20]; 9 float objective; /*客观题得分*/ 10 float subjective; /*操作题得分*/ 11 float sum; 12 char level[10]; 13 }STU; 14 15 // 函数声明 16 void input(STU s[], int n); 17 void output(STU s[], int n); 18 void process(STU s[], int n); 19 20 int main() { 21 STU stu[N]; 22 23 printf("录入%d个考生信息: 准考证号,姓名,客观题得分(<=40),操作题得分(<=60)\n", N); 24 input(stu, N); 25 26 printf("\n对考生信息进行处理: 计算总分,确定等级\n"); 27 process(stu, N); 28 29 printf("\n打印考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级\n"); 30 output(stu, N); 31 32 return 0; 33 } 34 35 // 录入考生信息:准考证号,姓名,客观题得分,操作题得分 36 void input(STU s[], int n) { 37 int i; 38 for(i=0;i<n;i++) 39 scanf("%ld%s%f%f",&s[i].id,s[i].name,&s[i].objective,&s[i].subjective); 40 } 41 42 //输出考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级 43 void output(STU s[], int n) { 44 int i; 45 printf("准考证号 姓名 客观题得分 操作题得分 总分 等级\n"); 46 for(i=0;i<n;i++) 47 printf(" %-9ld%-10s%-13.2f%-10.2f%-7.2f%-8s\n", 48 s[i].id,s[i].name,s[i].objective,s[i].subjective,s[i].sum,s[i].level); 49 } 50 51 // 对考生信息进行处理:计算总分,排序,确定等级 52 void process(STU s[], int n) { 53 int i,j,k; 54 int a1,a2; //用来表示10%和50%两个分界点 55 a1=(int)(N*0.1),a2=(int)(N*0.5); 56 STU temp; 57 for(i=0;i<n;i++) 58 s[i].sum=s[i].objective+s[i].subjective; 59 for(j=0;j<n-1;j++) 60 for(k=0;k<n-j-1;k++) 61 if(s[k].sum<s[k+1].sum) 62 { 63 temp=s[k]; 64 s[k]=s[k+1]; 65 s[k+1]=temp; 66 } 67 for(i=0;i<a1;i++) 68 strcpy(s[i].level,"优秀"); 69 for(i=a1;i<a2;i++) 70 strcpy(s[i].level,"合格"); 71 for(i=a2;i<n;i++) 72 strcpy(s[i].level,"不合格"); 73 }
• 运行结果截图
Part2: 共用体类型及编程示例
共用体与结构体类型的区别小结:
|
结构体 |
共用体 |
语法格式 |
Struct [结构体名] |
Union [共用体名] |
存储空间 |
不同变量分别存储 |
多变量共享存储空间 |
初始化 |
可以 |
不能赋初值 |
总空间大小 |
等于各成员总长度 |
等于最大成员占据的空间 |
Part3: 枚举类型及编程示例
小结:(1)枚举是一系列命名的整型常量,枚举类型用来描述离散的、有限的数据。
(2)枚举类型不能直接输入、输出枚举值,每个枚举常量都对应一个整数值,在输入时,需要输入枚举值对应的整数值,所以需要使用类型转换。在输出枚举值时,也需要进行类型转换。
(3)只能把枚举值赋予枚举变量,而不能把一个int型数值赋值给一个枚举类型的变量。如一定要把数值赋予枚举变量,则必须用强制类型转换。
【实验总结和体会】
结构体能够将一组具有逻辑相关性的数据结合到一起,具有很强的实用性,在具体编程中除了一些语法格式外,大多数感觉还是第五章数组的知识;
在实验ex1_3中,每次测试程序都要重新输入十组数据,很耗费时间,想知道能否在主函数中将结构体部分初始化来达到题目要求。
标签:nio std text 变量共享 区别 一起 体会 spl ret
原文地址:https://www.cnblogs.com/weiyuyang/p/10980364.html