当前位置:首页 > 题解目录 > 正文内容

【题解】公式成绩

亿万年的星光5年前 (2021-03-13)题解目录8312

【题目描述】

学校的期中考试到了。 gp 老师一共收集到 n 个学生的成绩,每个学生有 5 科成绩,分别是语文、数学、英语、政治、历史。(ai,bi,ci,di,ei) gp 老师突发奇想,他用 m 条公式来评价学生的成绩,也就是说,每条公式都单独评价一个指定的学生。 公式的形式为 Mark=kj1*ai+kj2*bi+kj3*ci+kj4*di+kj5*ei 现在 gp 老师懒得计算,他把这个任务交给了你,请你按照数据给出的 m 条公式,分别计算出 m 个指定的学生 对应的分数(mark)值。

【输入描述】

第 1 行为 n,m。 

第 2~ n+1 行,每行有五个正整数 ai,bi,ci,di,ei,分别为五科成绩 

第 n+2 ~n+1+m 行,每行有六个整数 ki1,ki2,ki3,ki4,ki5,pi,分别为公式的系数和第 pi 个学生

【输出描述】

一行 m 个数,分别为 m 条公式对应学生的分数值

【样例输入】

3 2
1 2 3 4 5
5 8 2 1 3
4 2 9 3 5
3 2 1 0 5 2
1 2 3 4 5 1

【样例输出】

48 55

【数据范围】

n<=1000 ai,bi,ci,di,ei<=1000 -1000<=ki<=1000
保证所有数据都是整数

【题目分析】


  • 中等程度的模拟题,问题的难点在于没看懂输入样例

  • 输入样例的第n+2到n+1+m行,最后一个数表示第pi个学生。

  • 注意输出的时候每个数用空格隔开,如果你回车或者换行答案也是错的。

  • 输入的时候也比较麻烦。但是比较好的一点就是锁定了5门成绩和5个公式系数

  • 一个思路是都看成一维数组,然后用整数去取。另一个比较好的思路是看成二维数组,这个方法比较直观。

  • 实际的处理结果要看m的次数。




【参考答案】

#include<iostream>
using namespace std;
int x[1005][1005],y[1005][1005],n,m; //分别表示成绩,系数,第n个人 
int main(){
	cin>>n>>m;//读入n和m
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=5;j++)//锁定5列 
			cin>>x[i][j];
	}
	for(int i=1; i<=m;i++)
	{
		for(int j=1; j<=6;j++) //锁定6列 
			cin>>y[i][j];
	}
	//处理数据	
	for(int i=1;i<=m;i++)
	{
		int ans =0;
		int tmp = y[i][6];   //取末尾数表示第n个学生
		for(int j=1;j<=5;j++)
		{
			ans+=x[tmp][j]*y[i][j];		
		}		
		cout<<ans<<" "; 
	}
	return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

【题解】最大平方因子

【题目描述】给定一个整数 n,请找出 n 的最大平方因子。所谓平方因子,就是一个 n 的因子,且是一个完全平方数。最大平方因子就是 n&nb...

【题解】使每位学生都有座位的最少移动次数

【题目描述】一个房间里有 n 个 空闲 座位和 n 名 站着的 学生,房间用一个数轴表示。给你一个长度为 n&...

【题解】尼科彻斯定理

【题目描述】 验证尼科彻斯定理,即:任何一个整数m的立方都可以写成m个连续奇数之和。【输入描述】任一正整数【输出描述】该数的立方分解为一串连续奇数的和【样例输入】13【样例输出】13*13*...

【题解】01背包

【题目描述】一个旅行者有一个最多能装 M 公斤的背包,现在有 n 件物品,它们的重量分别是W1,W2,...,Wn,它们的价值分别为C1,C2,...,Cn,求旅行者能获得最大总价值。【输入描述】第一...

【题解】翻手算法

翻手算法(fanshou.cpp) 【问题描述】 ⼩酷爱算法,他在编程珠玑⼀书中了解到了⼀种新的算法——翻⼿算法,为了更好的理解算 法,⼩明找来⼀叠纸牌,每⼀张纸牌上只有⼀个⼤写或...

【题解】大整数加法

【题目描述】求两个不超过200位的非负整数的和。【输入】有两行,每行是一个不超过200位的非负整数,可能有多余的前导0。【输出】一行,即相加后的结果。结果里不能有多余的前导0,即如果结果是342,那么...