考试排名 内存限制: 256 Mb时间限制: 1000 ms 题目描述 某学校的某次考试成绩以等第形式出现的,每名学生的成绩都是ABCD 中的一个。 学校有 n n 个班级,小爱想根据这次考试中 A 的比例,从高到低为这些班级排序;若出现两个班级 A 的比例相同,就按 B 的比例从高到低排序;若再相同,就按照 C 的比例;若再相同,就按照班级人数从大到小排序;若再相同,就按照班级编号从小到大排序。 请帮助小爱完成这个任务。 输入格式 第一行:单个整数 n n。 第二行到第 n + 1 n+1 行:第 i + 1 i+1 行有一个字符串,表示第 i i 个班级的学生成绩,每个字符代表一个学生的成绩。 输出格式 只有一行:按照班级排名先后顺序输出 n n 个整数,每个整数代表一个班级的编号。 数据范围 对于 50 % 50% 的数据, 1 ≤ n ≤ 100 1≤n≤100; 对于 100 % 100% 的数据, 1 ≤ n ≤ 10000 1≤n≤10000,且每个班级人数不超过 100 100 人。 样例数据 输入: 3 ABAACAA DDABBB BAB


以下是解决此问题的Python代码: ```python # 读取班级数量 n = int(input()) # 存储每个班级的信息,包括班级编号、A比例、B比例、C比例和班级人数 classes = [] for i in range(n): # 读取每个班级的成绩字符串 scores = input() # 计算班级人数 class_size = len(scores) # 计算A的数量 count_A = scores.count('A') # 计算B的数量 count_B = scores.count('B') # 计算C的数量 count_C = scores.count('C') # 计算A的比例 ratio_A = count_A / class_size if class_size > 0 else 0 # 计算B的比例 ratio_B = count_B / class_size if class_size > 0 else 0 # 计算C的比例 ratio_C = count_C / class_size if class_size > 0 else 0 # 将班级信息添加到列表中,班级编号从1开始 classes.append((i + 1, ratio_A, ratio_B, ratio_C, class_size)) # 定义排序规则 def custom_sort_key(item): # 按照A的比例从高到低排序,若相同则按B的比例从高到低排序, # 若再相同则按C的比例从高到低排序,若再相同则按班级人数从大到小排序, # 若再相同则按班级编号从小到大排序 return (-item[1], -item[2], -item[3], item[4], item[0]) # 对班级列表进行排序 classes.sort(key=custom_sort_key) # 提取排序后的班级编号 sorted_class_ids = [class_info[0] for class_info in classes] # 输出排序后的班级编号 print(" ".join(map(str, sorted_class_ids))) ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 在计算比例时,要注意分母不能为零,需要进行特殊处理,避免出现除零错误。 2. 排序规则的定义要准确,注意正负号的使用,以实现从高到低或从大到小的排序。 3. 输出结果时,要将整数列表转换为字符串并以空格连接,确保输出格式符合要求。 [2025-08-13 15:59:06 | AI写代码神器 | 542点数解答]
- 考试排名 内存限制: 256 Mb时间限制: 1000 ms 题目描述 某学校的某次考试成绩以等第形式出现的,每名学生的成绩都是ABCD 中的一个。 学校有 n n 个班级,小爱想根据这次考试中 A 的比例,从高到低为这些班级排序;若出现两个班级 A 的比例相同,就按 B 的比例从高到低排序;若再相同,就按照 C 的比例;若再相同,就按照班级人数从大到小排序;若再相同,就按照班级编号从小到大排序。 请帮助小爱完成这个任务。 输入格式 第一行:单个整数 n n。 第二行到第 n + 1 n+1 行:第 i + 1 i+1 行有一个字符串,表示第 i i 个班级的学生成绩,每个字符代表一个学生的成绩。 输出格式 只有一行:按照班级排名先后顺序输出 n n 个整数,每个整数代表一个班级的编号。 数据范围 对于 50 % 50% 的数据, 1 ≤ n ≤ 100 1≤n≤100; 对于 100 % 100% 的数据, 1 ≤ n ≤ 10000 1≤n≤10000,且每个班级人数不超过 100 100 人。 样例数据 输入: 3 ABAACAA DDABBB BAB(542点数解答 | 2025-08-13 15:59:06)65
- 考试排名 内存限制: 256 Mb时间限制: 1000 ms 题目描述 某学校的某次考试成绩以等第形式出现的,每名学生的成绩都是ABCD 中的一个。 学校有 n n 个班级,小爱想根据这次考试中 A 的比例,从高到低为这些班级排序;若出现两个班级 A 的比例相同,就按 B 的比例从高到低排序;若再相同,就按照 C 的比例;若再相同,就按照班级人数从大到小排序;若再相同,就按照班级编号从小到大排序。 请帮助小爱完成这个任务。 输入格式 第一行:单个整数 n n。 第二行到第 n + 1 n+1 行:第 i + 1 i+1 行有一个字符串,表示第 i i 个班级的学生成绩,每个字符代表一个学生的成绩。 输出格式 只有一行:按照班级排名先后顺序输出 n n 个整数,每个整数代表一个班级的编号。 数据范围 对于 50 % 50% 的数据, 1 ≤ n ≤ 100 1≤n≤100; 对于 100 % 100% 的数据, 1 ≤ n ≤ 10000 1≤n≤10000,且每个班级人数不超过 100 100 人。 样例数据 输入: 3 ABAACAA DDABBB BAB(800点数解答 | 2025-08-13 16:00:03)68
- 三倍子串 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定一个十进制正整数 n n,请问可以从 n n 中截取多少种不同的子串,使得子串构成的数字是 3 3 的倍数。 例如:当 n = 1234 n=1234 时,有且仅有 3 3, 12 12, 123 123, 234 234 这四个子串是 3 3 的倍数。 输入格式 单个整数:表示输入的数字 n n 输出格式 单个整数:表示 3 3 的倍数的子串数量。 数据范围 对于 20 % 20% 的数据, 1 ≤ n ≤ 1 0 9 1≤n≤10 9 ; 对于 50 % 50% 的数据, 1 ≤ n ≤ 1 0 100 1≤n≤10 100 ; 对于 70 % 70% 的数据, 1 ≤ n ≤ 1 0 1000 1≤n≤10 1000 ; 对于 100 % 100% 的数据, 1 ≤ n ≤ 1 0 100000 1≤n≤10 100000 样例数据 输入: 95764 输出: 6 说明: 子串6,9,57,576,957,9576是3的倍数 输入: 1111 输出: 2 说(486点数解答 | 2025-08-29 11:52:55)82
- 买二送一 内存限制: 256 Mb时间限制: 1000 ms 题目描述 我们需要买 n n 本书,第 i i 本书的价格为 a i a i 。 现有买二送一的促销活动:凡购买两本书,可以免费带走第三本书,但免费书的价格不能超过两本付费书中任意一本的价格即可。 请问,买下全部的书最少需要多少钱? 输入格式 第一行:单个整数表示 n n; 第二行: n n 个整数表示 a 1 , a 2 , … , a n a 1 ,a 2 ,…,a n 。 输出格式 单个整数:表示将所有书买下的最少钱数。 数据范围 对于 40 % 40% 的分数, 1 ≤ n ≤ 100 1≤n≤100; 对于 70 % 70% 的分数, 1 ≤ n ≤ 5000 1≤n≤5000; 对于 100 % 100% 的分数, 1 ≤ n ≤ 100 , 000 1≤n≤100,000, 1 ≤ a i ≤ 30 , 000 1≤a i ≤30,000。 样例数据 输入: 6 1 3 2 4 5 6 输出: 16 说明: 买2与3,送1; 买5与6,送4。 语言(315点数解答 | 2025-08-14 15:09:51)86
- c语音 定义一个结构体student,其中包含的成员为char no[10];char name[10];float score。设有5个学生,从键盘输入其信息,按成绩的升序排序。并输出这5个学生排序后的信息。 输入格式: "%s%s%f" 输出格式: "请输入第%d位同学的信息:姓名 学号 成绩\n" "%s,%s,%.0f\n" 输入样例: 张三 10001 98↙ 李四 10002 100↙ 王五 10003 95↙ 赵六 10004 99↙ 钱七 10005 93↙ 输出样例: 请输入第1位同学的信息:姓名 学号 成绩↙ 请输入第2位同学的信息:姓名 学号 成绩↙ 请输入第3位同学的信息:姓名 学号 成绩↙ 请输入第4位同学的信息:姓名 学号 成绩↙ 请输入第5位同学的信息:姓名 学号 成绩↙ 钱七,10005,93↙ 王五,10003,95↙ 张三,10001,98↙ 赵六,10004,99↙ 李四,10002,100↙(373点数解答 | 2024-10-30 00:37:20)293
- 定义一个结构体student,其中包含的成员为char no[10];char name[10];float score。设有5个学生,从键盘输入其信息,按成绩的升序排序。并输出这5个学生排序后的信息。 输入格式: "%s%s%f" 输出格式: "请输入第%d位同学的信息:姓名 学号 成绩\n" "%s,%s,%.0f\n" 输入样例: 张三 10001 98 李四 10002 100 王五 10003 95 赵六 10004 99 钱七 10005 93 输出样例: 请输入第1位同学的信息:姓名 学号 成绩 请输入第2位同学的信息:姓名 学号 成绩 请输入第3位同学的信息:姓名 学号 成绩 请输入第4位同学的信息:姓名 学号 成绩 请输入第5位同学的信息:姓名 学号 成绩 钱七,10005,93 王五,10003,95 张三,10001,98 赵六,10004,99 李四,10002,100(354点数解答 | 2024-10-30 18:45:58)229
- c语言定义一个结构体student,其中包含的成员为char no[10];char name[10];float score。设有5个学生,从键盘输入其信息,按成绩的升序排序。并输出这5个学生排序后的信息。 输入格式: "%s%s%f" 输出格式: "请输入第%d位同学的信息:姓名 学号 成绩\n" "%s,%s,%.0f\n" 输入样例: 张三 10001 98↙ 李四 10002 100↙ 王五 10003 95↙ 赵六 10004 99↙ 钱七 10005 93↙ 输出样例: 请输入第1位同学的信息:姓名 学号 成绩↙ 请输入第2位同学的信息:姓名 学号 成绩↙ 请输入第3位同学的信息:姓名 学号 成绩↙ 请输入第4位同学的信息:姓名 学号 成绩↙ 请输入第5位同学的信息:姓名 学号 成绩↙ 钱七,10005,93↙ 王五,10003,95↙ 张三,10001,98↙ 赵六,10004,99↙ 李四,10002,100↙(373点数解答 | 2024-10-31 19:49:58)218
- c语音定义一个结构体student,其中包含的成员为char no[10];char name[10];float score。设有5个学生,从键盘输入其信息,按成绩的升序排序。并输出这5个学生排序后的信息。 输入格式: "%s%s%f" 输出格式: "请输入第%d位同学的信息:姓名 学号 成绩\n" "%s,%s,%.0f\n" 输入样例: 张三 10001 98↙ 李四 10002 100↙ 王五 10003 95↙ 赵六 10004 99↙ 钱七 10005 93↙ 输出样例: 请输入第1位同学的信息:姓名 学号 成绩↙ 请输入第2位同学的信息:姓名 学号 成绩↙ 请输入第3位同学的信息:姓名 学号 成绩↙ 请输入第4位同学的信息:姓名 学号 成绩↙ 请输入第5位同学的信息:姓名 学号 成绩↙ 钱七,10005,93↙ 王五,10003,95↙ 张三,10001,98↙ 赵六,10004,99↙ 李四,10002,100↙(326点数解答 | 2025-01-01 20:11:47)203
- 题目描述 请根据邮件的重量和用户选择是否加急计算邮费。计算规则: 重量在 1000 1000 以内(包括),基本费 8 8 元; 超过 1000 1000 克的部分,每 500 500 克加收超重费 4 4 元,不足 500 500 克部分按 500 500 克计算; 如果用户选择加急,多收 5 5 元。 输入格式 一行,包含一个正整数 x x 和一个字符 c(y 或 n),之间用一个空格隔开,分别表示重量和是否加急。 如果字符是 y,说明选择加急;如果字符是 n,说明不加急。 输出格式 输出一行一个正整数,表示邮费。 输入输出样例 输入 #1复制 1200 y 输出 #1复制 17 说明/提示 对于100%数据 1 ≤ x ≤ 1 0 6 1≤x≤10 6 在洛谷, 享受 coding 的欢乐(88点数解答 | 2024-11-09 15:33:30)284
- 题目描述 请根据邮件的重量和用户选择是否加急计算邮费。计算规则: 重量在 1000 1000 以内(包括),基本费 8 8 元; 超过 1000 1000 克的部分,每 500 500 克加收超重费 4 4 元,不足 500 500 克部分按 500 500 克计算; 如果用户选择加急,多收 5 5 元。 输入格式 一行,包含一个正整数 x x 和一个字符 c(y 或 n),之间用一个空格隔开,分别表示重量和是否加急。 如果字符是 y,说明选择加急;如果字符是 n,说明不加急。 输出格式 输出一行一个正整数,表示邮费。 输入输出样例 输入 #1复制 1200 y 输出 #1复制 17 说明/提示 对于100%数据 1 ≤ x ≤ 1 0 6 1≤x≤10 6 在洛谷, 享受 coding 的欢乐(554点数解答 | 2024-11-09 15:34:05)290
- 请根据邮件的重量和用户选择是否加急计算邮费。计算规则: 重量在 1000 1000 以内(包括),基本费 8 8 元; 超过 1000 1000 克的部分,每 500 500 克加收超重费 4 4 元,不足 500 500 克部分按 500 500 克计算; 如果用户选择加急,多收 5 5 元。 输入格式 一行,包含一个正整数 x x 和一个字符 c(y 或 n),之间用一个空格隔开,分别表示重量和是否加急。 如果字符是 y,说明选择加急;如果字符是 n,说明不加急。 输出格式 输出一行一个正整数,表示邮费。 输入输出样例 输入 #1复制 1200 y 输出 #1复制 17 说明/提示 对于100%数据 1 ≤ x ≤ 1 0 6 1≤x≤10 6(244点数解答 | 2024-12-31 19:36:29)209
- 限制: 256 Mb时间限制: 1000 ms 题目描述 给定一个整数 n n,请打印一个具有 n n 层结构的三角形金字塔,例如当 n = 3 n=3 时,打印如下图形: /\ /__\ /\ /\ /__\/__\ /\ /\ /\ /__\/__\/__\ 输入格式 单个整数:表示 n n。 输出格式 根据题意输出层次为 n n 的三角形金字塔。 数据范围 1 ≤ n ≤ 30 1≤n≤30。 样例数据 输入: 3 输出: /\ /__\ /\ /\ /__\/__\ /\ /\ /\ /__\/__\/__\ 输入: 8 输出: /\ /__\ /\ /\ /__\/__\ /\ /\ /\ /__\/__\/__\ /\ /\ /\ /\ /__\/__\/__\/__\ (186点数解答 | 2025-08-07 11:10:40)77