实验6

Posted ability-1206

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实验6相关的知识,希望对你有一定的参考价值。

 

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的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段6——CSS选择器

20155201 李卓雯 《网络对抗技术》实验一 逆向及Bof基础

缓冲区溢出漏洞实验 20199321

使用 React 实验性中继片段:缺少属性 '"$fragmentRefs"'

找到我的自定义代码片段 Xcode 6?

[NTUSTISC pwn LAB 6]rop&Return to plt实验