码迷,mamicode.com
首页 > 其他好文 > 详细

实验六

时间:2019-06-05 18:00:21      阅读:88      评论:0      收藏:0      [点我收藏+]

标签: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_2.cpp

运行结果截图

技术图片

 程序源码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 }
ex1_3.cpp

• 运行结果截图

技术图片

Part2: 共用体类型及编程示例

 共用体与结构体类型的区别小结:

 

 

结构体

共用体

语法格式

Struct  [结构体名]

Union  [共用体名]

存储空间

不同变量分别存储

多变量共享存储空间

初始化

可以

不能赋初值

总空间大小

等于各成员总长度

等于最大成员占据的空间

Part3: 枚举类型及编程示例

小结:(1)枚举是一系列命名的整型常量,枚举类型用来描述离散的、有限的数据。

        (2)枚举类型不能直接输入、输出枚举值,每个枚举常量都对应一个整数值,在输入时,需要输入枚举值对应的整数值,所以需要使用类型转换。在输出枚举值时,也需要进行类型转换。

          (3)只能把枚举值赋予枚举变量,而不能把一个int型数值赋值给一个枚举类型的变量。如一定要把数值赋予枚举变量,则必须用强制类型转换。

【实验总结和体会】


         结构体能够将一组具有逻辑相关性的数据结合到一起,具有很强的实用性,在具体编程中除了一些语法格式外,大多数感觉还是第五章数组的知识;

       在实验ex1_3中,每次测试程序都要重新输入十组数据,很耗费时间,想知道能否在主函数中将结构体部分初始化来达到题目要求。

实验六

标签:nio   std   text   变量共享   区别   一起   体会   spl   ret   

原文地址:https://www.cnblogs.com/weiyuyang/p/10980364.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!