蓝桥杯官网 试题 PREV-225 历届真题 成绩分析【第十一届】【决赛】【研究生组】【C++】【C】【Java】【Python

举报
红目香薰 发表于 2022/05/31 18:42:19 2022/05/31
1.1k+ 0 0
【摘要】 ​ 为帮助大家能在6月18日的比赛中有一个更好的成绩,我会将蓝桥杯官网上的历届决赛题目的四类语言题解都发出来。希望能对大家的成绩有所帮助。今年的最大目标就是能为【一亿技术人】创造更高的价值。资源限制内存限制:256.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s​编辑​编辑C++#include <bits/stdtr1c++.h>using...

 为帮助大家能在6月18日的比赛中有一个更好的成绩,我会将蓝桥杯官网上的历届决赛题目的四类语言题解都发出来。希望能对大家的成绩有所帮助。

今年的最大目标就是能为【一亿技术人】创造更高的价值。


资源限制

内存限制:256.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s

编辑编辑

C++

#include <bits/stdtr1c++.h>
using namespace std::tr1;
using namespace std;
int main()
{
    int n;
    cin >> n;
    int sum = 0, tp;
    int mx, mi;
    mx = 0, mi = 100;
    for (int i = 0; i < n; i++)
    {
        cin >> tp;
        sum += tp;
        mx = max(mx, tp);
        mi = min(mi, tp);
    }
    unordered_map<int, int> ump;
    printf("%d\n%d\n%.2f\n", mx + ump.size(), mi, 1.0 * sum / n + 1e-8);
    return 0;
}

C

#include<stdio.h>
int main()
{
    int i;
    float p, max = -1, min = 1000;
    float grades,av, sum = 0;
    scanf("%f", &p);
    for(i=0;i<p;i++)
    {
        scanf("%f", &grades);
        if (grades < min)
            min = grades;
        if (grades > max)
            max = grades;
        sum += grades;
    }
    av = sum / p;
    printf("%.0f\n%.0f\n%.2f", max, min,av);
    return 0;
}

Java

import java.io.*;
import java.math.BigDecimal;
public class Main {
	static class Input{
		StreamTokenizer in = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
		public int nextInt() throws IOException{
			in.nextToken();
			return (int)in.nval;
		}
	}
	
	public static void main(String args[]) throws Exception{
		Input in = new Input();
		int n = in.nextInt();
		int sum = 0;
		int max = 0;
		int min = Integer.MAX_VALUE;
		for(int i=0;i<n;i++) {
			int s = in.nextInt();
			if(s > max) {
				max = s;
			}
			if(s < min) {
				min = s;
			}
			sum +=s;
		}
		BigDecimal r = new BigDecimal(sum+"").divide(new BigDecimal(n+""), 2, BigDecimal.ROUND_HALF_UP);
		System.out.println(max);
		System.out.println(min);
		System.out.println(r);
	}
	
}

Python

n = int(input())
lists = []
sum1 = 0
for i in range(0, n):
    lists.append(int(input()))
for i in range(0, len(lists)):
    sum1 += lists[i]
print(max(lists))
print(min(lists))
print('%0.2f' % (sum1/len(lists)))

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。