求大佬用简单的c++帮我,求求了

 

#include "stdio.h"
#define N 2
struct student{
	int stuNo;
	char stuName[20];
	float kq;
	float ktbx;
	float pszy;
	float ktbj;
	float score;
	float total;
}stu[N];
int main(){
	//输入成绩 
	for(int i=0;i<N;i++){
		printf("请输入第%d个同学的学号、姓名、考勤、课堂表现、平时作业、课堂笔记、末考成绩(空格隔开)\n",i+1);
		scanf("%d %s %f %f %f %f %f",&stu[i].stuNo,stu[i].stuName,&stu[i].kq,&stu[i].ktbx,&stu[i].pszy,&stu[i].ktbj,&stu[i].score);
		stu[i].total=(stu[i].kq*0.3+stu[i].ktbx*0.3+stu[i].pszy*0.3+stu[i].ktbj*0.1)*0.3+stu[i].score*0.7;
	}
	//排序
	for(int i = 0; i < N - 1; i++) {
        for(int j = 0; j < N - 1 - i; j++) {
        	// 相邻元素两两对比
            if(stu[j].total < stu[j+1].total) {
            	struct student temp;
            	//元素交换
                temp = stu[j+1];       
                stu[j+1] = stu[j];
                stu[j] = temp;
            }
        }
    }
    printf("学号\t姓名\t总分\n");
    for(int i=0;i<N;i++){
    	printf("%d\t%s\t%.2f\n",stu[i].stuNo,stu[i].stuName,stu[i].total);
	}
	return 0;
} 

代码如上,万望采纳。

 


#include "stdio.h"

#define N 2
struct student{
	int id;
	char name[20];
	int kaoqun;
	int biaoxian;
	int zuoye;
	int biji;
	int sum;
}stud[N],t;

int main()
{
	int i,j;
	for(i=0;i<N;i++){
		printf("请输入第%d个学生信息\n",i+1);
		scanf("%d %s",&stud[i].id,&stud[i].name);
		fflush(stdin);
		scanf("%d %d %d %d",&stud[i].kaoqun,&stud[i].biaoxian,&stud[i].zuoye,&stud[i].biji);
		stud[i].sum = stud[i].kaoqun*0.3+stud[i].biaoxian*0.3+stud[i].zuoye*0.3+stud[i].biji*0.1;
	}
	
	//排序
	
	for (i = 0; i < N - 1; i++){
	    for (j = 0; j < N - 1 - i; j++){ //按成绩对学生信息进行排序
	        if (stud[j].sum > stud[j + 1].sum){ //整型数字的比较
	            t = stud[j];
	            stud[j] = stud[j + 1];
	            stud[j + 1] = t;
	        }
	    }
	}
	//打印
	printf("学号\t姓名\t考勤\t表现\t作业\t笔记\t总分\t\n");
    for (i = 0; i < N; i++){
        printf("%d\t", stud[i].id);
        printf("%s\t", stud[i].name);
        printf("%d\t", stud[i].kaoqun);
        printf("%d\t", stud[i].biaoxian);
        printf("%d\t", stud[i].zuoye);
        printf("%d\t", stud[i].biji);
        printf("%d \n", stud[i].sum);
    }
	
    return 1;
}

 

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632