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

实验六

时间:2019-06-11 01:21:13      阅读:106      评论:0      收藏:0      [点我收藏+]

标签:nal   数值   数组   int   fail   构造   scanf   level   不能   

#include<stdio.h>
#include<string.h>
#define N 3
typedef struct student 
{
	int id;
	char name[20];
	char subject[20];
	float perf;
	float mid;
	float final;
	float total;
	char level[10];
 } STU;
void calc(STU[],int);
int fail(STU[],STU[],int);
void sort(STU[],int);
void print(STU[],int);
void input(STU[],int);
int main()
{
	STU st[N],fst[N];
	int k;
	printf("\n成绩录入\n");
	input(st,N);
	printf("\n成绩处理...\n");
	calc(st,N);
	k=fail(st,fst,N);
	sort(st,N);
	printf("\n学生成绩排名情况:\n");
	print(st,N);
	printf("不几个学生信息:\n");
	print(fst,k);
	return 0;
}
void input(STU s[],int n)
{
	int i;
	for(i=0;i<n;i++)
	{
	    scanf("%d%s%s%f%f%f",&s[i].id,s[i].name,s[i].subject,&s[i].perf,&s[i].mid,&s[i].final);
	}
}
void calc(STU s[],int n)
{
	int i;
	for(i=0;i<n;i++)
	{
		s[i].total=s[i].perf*0.2+s[i].mid*0.2+s[i].final*0.6;
		if(s[i].total>=90)
		strcpy(s[i].level,"优");
		else if(s[i].total>=80&&s[i].total<90)
		strcpy(s[i].level,"中");
		else if(s[i].total>=60&&s[i].total<80)
		strcpy(s[i].level,"及格");
		else if(s[i].total<60)
		strcpy(s[i].level,"不及格");
	}
}
int fail(STU s[],STU t[],int n)
{
	int i,k=0;
	for(i=0;i<n;i++)
	if(s[i].total<60)
	t[k++]=s[i];
	return k;
}
void sort(STU s[],int n)
{
	int i,j;
	STU temp;
    for(i=0;i<n-1;i++)
   {
   	for(j=0;j<n-1-i;j++)
   	  if(s[j].total<s[j+1].total)
   	  {
   	  	temp=s[j];
   	  	s[j]=s[j+1];
   	  	s[j+1]=temp;
		 }
   }
}
void print(STU s[],int n)
{
	int i;
	printf("学号     姓名   考试科目   平时成绩 期中成绩 总评成绩 成绩等级\n");
	for(i=0;i<n;i++)
	{
	    printf("%5d %10s%20s %5.1f %5.1f %5.1f %5.1f %10s\n",s[i].id,s[i].name,s[i].subject,s[i].perf,s[i].mid,s[i].final,s[i].total,s[i].level);
    }
}

  v技术图片

 

#include<stdio.h>
#define N 5
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;
}
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);
}
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);
}
int findMinlist(STU s[],STU t[],int n)
{
	int i,k,j=0;
	k=0;
	for(i=1;i<n;i++)
	{
		if(s[k].score>s[i].score)
		  k=i;
	}
	for(i=0;i<n;i++)
	{
		if(s[i].score==s[k].score)
		t[j++]=s[i];
	} 
	return j;
}
 

  vv技术图片

 

#include<stdio.h>
#include<string.h>
#define N 10
typedef struct student 
{
	long int id;
	char name[20];
	float subjective;
	float objective;
	float sum;
	char level[10];
 } STU;
 void input(STU s[],int n);
 void process(STU s[],int n);
void output(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打印考生完整信息:准考证号,姓名,客观题得分,操作题得分,总分,等级");
	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("%4d%4s%8.2f%8.2f%8.2f%8s\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;
  	for(i=0;i<n;i++)
  	s[i].sum=s[i].subjective+s[i].objective;
  	for(i=0;i<n;i++)
  	  if(s[i].sum>90)
  	    strcpy(s[i].level,"合格");
  	    else
  	       strcpy(s[i].level,"不合格");
}

   技术图片

枚举类型:
枚举类型可以把常用的常量列举出来,每一个常量可以附带信息和行为;
枚举类型不是构造类型,而是一种基本数据类型,;
枚举值是常量。
只能把枚举值赋予枚举变量,不能把元素的数值直接赋予枚举变量;
如果一定要把数值赋予枚举变量,必须用强制类型转换。
****尝试过用结构体指针书写,在用时,得格外注意指针所指结构体数组内容如何别改变,
这对主函数要调用多个子函数的程序来说很重要。
*****共用体成员共用一段区域,共用体比结构体占用内存小,它们的定义相似,在引用时共用体只能一次调用一个成员。


 

实验六

标签:nal   数值   数组   int   fail   构造   scanf   level   不能   

原文地址:https://www.cnblogs.com/0522GY1025/p/11001199.html

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