实验六

实验六小结

ex1-2.cpp

#include <stdio.h>

const int N=5;

// 定义结构体类型struct student,并定义STU为其别名 
typedef struct student {
    long no;
    char name[20];
    int score;     
}STU;

// 函数声明 
void input(STU s[], int n);
int findMinlist(STU s[], STU t[], int n);
void output(STU s[], int n);

int main() {
    STU stu[N], minlist[N];
    int count;
    
    printf("录入%d个学生信息\n", N);
    input(stu, N);
    
    printf("\n统计最低分人数和学生信息...\n");
    count = findMinlist(stu, minlist, N);
    
    printf("\n一共有%d个最低分,信息如下:\n", count);
    output(minlist, count);
     
    return 0;
} 

// 输入n个学生信息,存放在结构体数组s中 
void input(STU s[], int n) {
    int i;
    for(i=0; i<n; i++) 
        scanf("%ld %s %d", &s[i].no, s[i].name, &s[i].score);
} 

// 输出结构体s中n个元素信息
void output(STU s[], int n) {
    int i;
    for(i=0; i<n; i++)
        printf("%ld %s %d\n", s[i].no, s[i].name, s[i].score); 
} 

// 在结构体数组s中,查找最低分学生的记录,将其存入结构体数组s中
// 形参n是结构体数组s中元素个数
// 函数返回最低分的学生人数 
int findMinlist(STU s[], STU t[], int n) {
    // 补足函数实现
    int i,j,k=0;
        for(i=0;i<n-1;i++)
        {      t[0]=s[0];
               if(s[i].score>=s[i+1].score)
                       t[0]=s[i+1];
         }
         for(j=0;j<n;j++)
        {
                   if(s[j].score==t[0].score)
                        t[k++]=s[j];
         }
          return k;

    
} 

验证:

ex1-3.cpp

#include <stdio.h>
#include <string.h>
const int N = 10;
// 定义结构体类型struct student,并定义其别名为STU
typedef struct student {
long int id;
char name[20];
float objective; /*客观题得分*/
float subjective; /*操作题得分*/
float sum;

char level[10];
}STU;
// 函数声明
void input(STU s[], int n);
void output(STU s[], int n);
void process(STU s[], int n);
int main() {
STU stu[N];
printf("录入%d个考生信息: 准考证号,姓名,客观题得分(<=40),操作题得分(<=60)\n",N);
input(stu, N);
printf("\n对考生信息进行处理: 计算总分,确定等级\n");
process(stu, N);
printf("\n打印考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级\n");
output(stu, N);
return 0;
}

void input(STU s[], int n) {
    int i;
       for(i=0;i<n;i++){
           scanf("%ld %s %f %f",&s[i].id,s[i].name,&s[i].objective,&s[i].subjective);
       } 
} 

void output(STU s[], int n) {
    int i;
   for(i=0;i<n;i++){
   printf("%ld %s %f %f %f %s\n",s[i].id,s[i].name,s[i].objective,s[i].subjective,s[i].sum,s[i].level);
       }
   }

void process(STU s[], int n) {
    int i,j;
      STU t; 
       for(i=0;i<n;i++){
         s[i].sum=s[i].objective+s[i].subjective;
     } 
       for(i=0;i<n-1;i++){
           for(j=0;j<n-1-i;j++){
                if(s[j].sum<s[j+1].sum){
                   t=s[j];
                   s[j]=s[j+1];
                 s[j+1]=t;
               }    
           }
       }
for(i=0;i<n;i++){
    if(i==0)
    strcpy(s[i].level,"优秀");
    else if(i>=1&&i<=4)
    strcpy(s[i].level,"合格");
    else
    strcpy(s[i].level,"不合格");
    }
}

验证:

 

结构体: 各成员各自拥有自己的内存,各自使用互不干涉,同时存在的,遵循内存对齐原则一个struct变量的总长度等于所有成员的长度之和。

共用体: 各成员共用一块内存空间,并且同时只有一个成员可以得到这块内存的使用权(对该内存的读写),各变量共用一个内存首地址。因而,联合体比结构体更节约内存。一个union变量的总长度至少能容纳最大的成员变量,而且要满足是所有成员变量类型大小的整数倍。(不允许对联合体变量名U2直接赋值或其他操作。)(From CSDN)

枚举类型用于描述整型数据,不能直接输入输出

枚举变量可以隐式转换成int数值,int转换为枚举变量需要强制类型转换。

 

posted @ 2019-06-11 04:15  史潮洋  阅读(112)  评论(1编辑  收藏  举报