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;
}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...