一道题带来的激动

就在刚刚,我终于解决了一道困惑我许久的问题,并从中学到了很多新东西,答案正确的那一瞬间真的太激动了,先看题目(我还是个菜鸟,不要嘲讽我题目简单呜呜)

输入n个学生数据记录(姓名、学号,5门课成绩)算出总分并且进行排序,按总分最后从高到低输出这些数据。

输入

第一行输入学生的个数N接下来的N行输入学生的姓名,学号,5门科的成绩。

输出

一共输出N行,每行输出学生的姓名,学号,及总分(格式:total=?),每个数据相隔一个空格

输入样例 1 

3
A 200701 98 125 100 96 85
B 200702 100 100 100 100 120
C 200703 130 80 70 50 50

输出样例 1

B 200702 total=520
A 200701 total=504
C 200703 total=380
#include<stdio.h>
#include<ctype.h>
#include<stdbool.h>
#include<string.h>
#include<math.h>

//
//输入n个学生数据记录(姓名、学号,5门课成绩)算出总分并且进行排序,按总分最后从高到低输出这些数据。
//
//
//输入
//第一行输入学生的个数N接下来的N行输入学生的姓名,学号,5门科的成绩。
//
//
//输出
//一共输出N行,每行输出学生的姓名,学号,及总分(格式:total=?),每个数据相隔一个空格
//
//
//输入样例 1 
//
//3
//A 200701 98 125 100 96 85
//B 200702 100 100 100 100 120
//C 200703 130 80 70 50 50
//输出样例 1
//
//B 200702 total=520
//A 200701 total=504
//C 200703 total=380
//


int main()
{
	int i,j,x;
   struct Student{
   	char name[100];
   	int degree;
   	int score[5];
   	int sum;
   };
      int n;
      scanf("%d",&n);
      struct Student student[n];
      for(i=0;i<n;i++)
      {
      	student[i].sum=0;
	  }

	for(i=0;i<n;i++)
	{
		
		scanf("%s",&student[i].name);
		scanf("%d",&student[i].degree);
		for(x=0;x<5;x++)
		{
			scanf("%d",&student[i].score[x]);
			student[i].sum+=student[i].score[x];
		}
	}
	//把sum按从高到低排序
	
	 for(i=0;i<n-1;i++) 
	{
	for(j=0;j<n-i-1;j++)
	{
			if(student[j+1].sum>student[j].sum)
			{
			struct Student m;
			m=student[j+1];
			student[j+1]=student[j];
			student[j]=m;
			}
	}
	}

		for(i=0;i<n;i++){
	printf("%s %d total=%d\n",student[i].name,student[i].degree,student[i].sum);
    }
	return 0;
 } 


为了这道题目学会了结构体,冒泡排序等知识,真的让我收获很多,浅浅记录一下

### 关于蓝桥杯比赛目分数规则 蓝桥杯大赛作为一项面向全国高校学生的编程竞赛,其评分机制通常会根据赛事级别(如省赛或国赛)、参赛组别以及具体的目难度来分配分值。以下是关于蓝桥杯比赛中每道目对应分数的一些常见规则: #### 目分数分布 蓝桥杯的比赛目一般分为填空和编程两种类型。不同类型的目会有不同的分值设定。 - **填空**:这类目通常是考察选手的基础知识掌握情况,每道目的分值相对较低,大约在5到10分之间[^1]。 - **编程**:这是比赛的核心部分,主要测试选手的实际编码能力。编程的分值较高,通常分布在20至100分不等,具体取决于目的复杂度和解所需的知识范围[^2]。 #### 总体得分计算方式 总成绩由所有完成目所得分数累加而成。对于某些特定目,如果存在部分正确的情况,则可能会按照通过的测试点比例给予相应分数。例如,一道满分100分的目如果有十个独立测试点,而某位选手仅成功解决了其中六个,则最终得分为60分。 ```c // 示例代码展示如何处理多个输入并统计最大事件发生次数 #include <stdio.h> int main() { int n; scanf("%d", &n); int A[n], B[n], C[n]; int maxEvents = -1; int X = 0, Y = 0, Z = 0; for (int i = 0; i < n; ++i) { scanf("%d %d %d", &A[i], &B[i], &C[i]); X += A[i]; Y += B[i]; Z += C[i]; if ((X > Y + Z) || (Y > X + Z) || (Z > X + Y)) { maxEvents = i + 1; } } printf("%d\n", maxEvents); return 0; } ``` 上述代码片段展示了十四届蓝桥杯程序设计竞赛中的一道典型逻辑判断类问解决方法,虽然此段代码并非直接关联分数规则说明,但它体现了实际比赛中可能遇到的任务形式及其求解思路。 #### 特殊注意项 需要注意的是,在正式考试前官方往往会发布详细的《竞赛手册》,里面包含了确切的目描述、样例数据以及各的具体分值信息。因此建议参赛者提前查阅最新版的手册文档获取权威指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值