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

实验6

时间:2019-06-10 00:12:15      阅读:119      评论:0      收藏:0      [点我收藏+]

标签:cas   共享   color   枚举   code   level   课程   生成   返回   

 

Part. 1     结构体

1.验证性实验(自己编的,麻烦看看有没有bug)

/*学生成绩信息包括学号、姓名、考试课程、平时成绩、期中成绩、期末成绩、总评成绩和等级
(优:90-100、良:80-89、中:70-79、及格:60-69、不及格:<60)。
建立一个描述学生某科成绩的数据类型,其中总评成绩=平时成绩×20%+期中成绩×20%+期末成绩
×60%。
要求输入学生的平时成绩、期中成绩、期末成绩。分别用函数实现下面功能:
? 计算课程总评成绩并指出成绩等级。
? 输出不及格的学生信息。
? 按学生的总评成绩进行降序排列。*/
#include<stdio.h>
#include<string.h>
const int N=5;
typedef struct student{
	int id;          //学号 
	char name[80];    //姓名 
	char subject[80]; //学科 
	float per;        //平时成绩
	float mid;        //期中成绩 
	float final;      //期末成绩
	float total;      //总评成绩 
	char level[10];       //等级 
}STU;
    
void input(STU[],int);  /* 输入学生信息 */
void calc(STU[],int);        /* 计算总评和等级 */
int fail(STU[], STU [],int); /* 不及格学生统计 */
void sort(STU[],int);        /* 排序 */
void print(STU[]);      /* 输出学生信息 */

int main(){
	STU stu[N]={0},fst[N]={0};
	int num;         //记录不及格人数 
    printf("输入学生成绩:\n"); 
	printf("请依次输入\n学号、姓名、学科、平时成绩、期中、期末\n"); 
	input(stu,N);    //输入 
	calc(stu,N);     //计算总评和等级 
	sort(stu,N);     //排序 
	printf("\n学生排名情况\n");
	print(stu);
	num=fail(stu,fst,N);
    printf("\n") ;
    printf("/**************************************************************/\n");
    printf("\n其中不及格人数有%d人",num);
	if(num!=0){
	    printf(",分别是:\n");
	    print(fst);
	}
	return 0;
}

void input(STU st[],int n){
	int i;
	for(i=0;i<n;i++){
		scanf("%d %s %s %f %f %f",&st[i].id,
		st[i].name,st[i].subject,&st[i].per,
		&st[i].mid,&st[i].final);		
	}
}

void calc(STU st[],int n){
	int i;
	for(i=0;i<n;i++){
	    st[i].total=st[i].per*0.2+st[i].mid*0.2+st[i].final*0.6;
        switch((int)(st[i].total/10)){
        	case 10:; 
        	case 9: strcpy(st[i].level,"优秀");break; 
		    case 8: strcpy(st[i].level,"良好");break;
		    case 7: strcpy(st[i].level,"中等");break;
		    case 6: strcpy(st[i].level,"及格");break;
		    default:strcpy(st[i].level,"不及格");break; 
			}
    }
}


int fail(STU st[], STU fst[],int n){
	STU *p=fst;
	int i,k=0;
	for(i=0;i<n;i++){
		if(strcmp(st[i].level,"不及格")==0)
		*p++=st[i],k++;
	}
	return k;

} /* 不及格学生统计 */

void sort(STU st[],int n){
	STU temp;
	int i,j;
	for(i=0;i<n;i++)
	for(j=0;j<n-1-i;j++){
		if(st[j].total<st[j+1].total){
			temp=st[j];
			st[j]=st[j+1];
			st[j+1]=temp;
		}
    }
} 

void print(STU st[]){
	printf("/**************************************************************/\n");
	printf("学号\t姓名\t学科\t平时\t期中\t期末\t总成绩\t等级\n"); 
	STU *f=st;
	while(f->id){
    	printf("%-8d%-8s%-8s%.2f\t%.2f\t%.2f\t%.2f\t%s\n",
	    f->id,f->name,f->subject,f->per,
	    f->mid,f->final,f->total,f->level);
        f++;
    }
}

 截图如下

 技术图片

 

2.找出最低分并记录个数

#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,k=0,num=1;//记录最低分个数 
    
    for(i=1;i<n;i++){
        if(s[k].score>s[i].score)
            k=i,num=1;
        else if(s[k].score==s[i].score)
            num++;
    }   //找出最低分下标 
    
    int j=0;
    for(i=k;i<n;i++){
        if(s[k].score==s[i].score)
        t[j++]=s[i];
    }   //记录最低分信息    
    
    return num; 
}

技术图片

 

 

3.成绩处理

#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;
    printf("准考证号\t姓名\t客观题得分\t主观题得分\t总分\t等级\n");
    for(i=0;i<n;i++)
    printf("%-15ld%-10s%-9.2f\t %-10.2f\t%.2f\t%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;
    for(i=0;i<n;i++)//计算总分 
    s[i].sum=s[i].objective+s[i].subjective;
    
    STU mid;        //冒泡法排序 
    for(i=0;i<n;i++)
        for(j=0;j<n-i-1;j++)
            if(s[j].sum<s[j+1].sum){
            	mid=s[j];
            	s[j]=s[j+1];
            	s[j+1]=mid;
			}
            
    for(i=0;i<n;i++){   //确定等级    
        if(i+1<=n*0.1)   strcpy(s[i].level,"优秀"); 
	    else if(i+1>n*0.5)   strcpy(s[i].level,"不合格");
        else strcpy(s[i].level,"合格"); 
	}    
}

  

技术图片

 

 

Part.2  共用体

共用体与结构体类似,差异在于:

  结构体各个成员顺序排列储存,且有自己的独立储存位置;

  共用体所有成员共享同一片存储区,每时每刻只能保持一个成员的值。

 

 

Part.3 枚举类型

枚举是一系列命名的整型常量。

注意事项:

1.枚举值是常量,不可赋值;

2.只能把枚举值赋值给枚举变量,不能把元素的值赋值给枚举变量;

3.枚举元素不是字符常量,也不是字符串常量,无需加单、双引号;

4.枚举变量不能直接输入输出

 5.枚举类型可以赋值给int 类型,而int类型要类型转换才能赋值。

实验6

标签:cas   共享   color   枚举   code   level   课程   生成   返回   

原文地址:https://www.cnblogs.com/ability-1206/p/10991022.html

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