ZCMU--5180: gsy 的考试成绩(C语言)
创始人
2024-03-28 03:18:41
0

Description

众所周知,学校里有三种人

天天考满分的是学霸,天天考不及格的是学渣,还有一类比学霸更厉害的人——控分大佬

考试考满分不是最厉害的,最厉害的是想考几分考几分

而 gsy 作为一个学霸,希望自己再进一步成为控分大佬!

gsy 的学校考试模式很有趣,如果一张试卷总共有 m 道题,那么题目编号分别为 1,2,3...m,而第 i 题的分值为 i

而对于每道题,如果做对了就可以获得题目对应的分数,如果做错了则不会获得分数反而还要倒扣 1 分(不存在获得部分分的情况)

现在 gsy 希望自己可以考正好 n 分,她想知道一张试卷最少有多少题,她就可以正好控分到 n 分

Input

第一行包含一个正整数 T 表示共有 T 次询问

对于每次询问包含一个正整数 n 表示 gsy 希望考的分数

对于 30% 的数据,T≤3,1≤n≤10

对于 60% 的数据,T≤10,1≤n≤1000

对于 100% 的数据,T≤1000,1≤n≤10^6

Output

对于每一次询问输出一个正整数表示试卷中最少的题目数量

Sample Input

3
3
4
5

Sample Output

2
3
4

找规律,手写前15个就差不多知道了🎈

N   ans
1    1    ⬅
2    3
3    2    ⬅
4    3
5    4
6    3    ⬅
7    4
8    4
9    5
10   4    ⬅
11   5 
12   5 
13   5 
14   6 
15   5    ⬅

解析:如果输入的n等于1~m的总和(全做对),那么m此时就是最小的,然后发现如果不存在1~m全对使得总分为n,取第一个大于n的k满足(1~m的和=k),如果n==k-1,那么就需要最少m+1,否则就是m。

#include 
int a[1420];
int main()
{int t,n,i;for(i=1;i<=1414;i++) a[i]=a[i-1]+i;//预处理出1,3,6,10..... scanf("%d",&t);while(t--){scanf("%d",&n);for(i=1;i<=n;i++){if(n<=a[i])//找到第一个大于等于n的a[i]满足1~m的和 {if(n==a[i]-1) printf("%d\n",i+1);else printf("%d\n",i);break;}}}return 0;
}

相关内容

热门资讯

不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
APK正在安装,但应用程序列表... 这个问题可能是由于以下原因导致的:应用程序安装的APK文件可能存在问题。设备上已经存在同名的应用程序...
安卓文字转语音tts没有声音 安卓文字转语音TTS没有声音的问题在应用中比较常见,通常是由于一些设置或者代码逻辑问题导致的。本文将...
报告实验.pdfbase.tt... 这个错误通常是由于找不到字体文件或者文件路径不正确导致的。以下是一些解决方法:确认字体文件是否存在:...