L1-100 四项全能 - java

L1-100 四项全能


代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

栈限制

8192 KB


题目描述:

新浪微博上有一个帖子给出了一道题:全班有 50 人,有 30 人会游泳,有 35 人会篮球,有 42 人会唱歌,有 46 人会骑车,至少有( )人四项都会。

发帖人不会做这道题,但是回帖有会做的:每一个才艺是一个技能点,一共是 30 + 35 + 42 + 46 = 153 个技能点,50 个人假设平均分配,每人都会 3 个技能那也只有 150,所以至少有 3 人会四个技能。

本题就请你写个程序来自动解决这类问题:给定全班总人数为 n,其中有 m 项技能,分别有 k 1 、 k 2 、 . . . . . . 、 k m k_{1}、k_{2}、......、k_{m} k1、k2、......、km 个人会,问至少有多少人 m 项都会。

输入格式:

输入在第一行中给出 2 个正整数:n( 4 ≤ n ≤ 1000 4 \le n \le 1000 4≤n≤1000)和 m( 1 < m ≤ n / 2 1< m \le n / 2 1<m≤n/2),分别对应全班人数和技能总数。随后一行给出 m 个不超过 n 的正整数,其中第 i 个整数对应会第 i 项技能的人数。

输出格式:

输出至少有多少人 m 项都会。

输入样例:

50 4

30 35 42 46

输出样例:

3


求n个人中m个技能都会的同学有几个?


emmmmmmm

可以先计算出,每种技能会的人数。

那么 所有人m个技能都会的人数 - 已知技能会的人数 = 会m种及以下的人数

再 总人数 - 会m种及以下的人数 = 全会的人数

但是可能会出现 会m种及以下的人数 大于 总人数, 如果出现了这种情况的话,那么全会的人数为0

比如:

50 4

1 1 1 1


java 复制代码
import java.io.*;
import java.util.*;

public class Main
{

	public static void main(String[] args)
	{
		int n = sc.nextInt();
		int m = sc.nextInt();
		int ans = 0; // 技能会的人数
		for (int i = 1; i <= m; i++)
		{
			int x = sc.nextInt();
			ans += x;
		}

		int res = n * m - ans; // m种都会 - 技能会的人数 = 只会m种及以下的人数
		out.println(Math.max(0, n - res));

		out.flush();
		out.close();
	}

	static Scanner sc = new Scanner(System.in);
	static PrintWriter out = new PrintWriter(System.out);

}


如果有说错的 或者 不懂的 尽管提 嘻嘻

一起进步!!!


闪现

相关推荐
qq_416018722 分钟前
分布式缓存一致性
开发语言·c++·算法
SuperEugene7 分钟前
Vue Router 实战规范:path/name/meta 配置 + 动态 / 嵌套路由,统一团队标准|状态管理与路由规范篇
开发语言·前端·javascript·vue.js·前端框架
干啥啥不行,秃头第一名10 分钟前
STL容器内部实现剖析
开发语言·c++·算法
一直都在57211 分钟前
线程间的通信
java·jvm
2401_8318249618 分钟前
内存泄漏检测与防范
开发语言·c++·算法
GIOTTO情30 分钟前
Infoseek危机公关全链路技术解析:基于近期热点舆情的落地实践
java
includei30 分钟前
【JavaScript】华为机试_HJ20_密码验证合格程序
开发语言·javascript·华为
肖恭伟39 分钟前
Cursor Superpowers 零基础开发 Qt 界面
开发语言·qt
liuyao_xianhui1 小时前
优选算法_分治_快速排序_归并排序_C++
开发语言·数据结构·c++·算法·leetcode·排序算法·动态规划
我是人✓1 小时前
从零入门 Servlet:JavaWeb 核心组件的实操与理解
java·servlet