lin2144是一只小菜鸟,都是笨鸟先飞,lin2144想来个菜鸟先飞,他从0点出发
一开始的飞行速度为1m/s,每过一个单位时间lin2144的飞行速度比上一个单位时间的飞行速度快2m/s,问n (0 < n < 10^5)个单位时间之后lin2144飞了多远?
Input
输入一个T表示为有几组数据
每组数据输入一个n,表示lin2144飞行的时间.
Output
输出lin2144飞行了多远,因为数字很大,所以对10000取模.
Sample Input
2
1
2
Sample Output
1
4
这道题我刚开始还想用递归存速度,这样速度数组就100000+,仔细想想飞过的距离不就是首项为1,公差为2的等差数列,这样再利用求和公式,distance=na1+n(n-1)/2d=nn(d=2)!yeah~
#include<iostream>
#include<cstdio>
#include<algorithm>
#define N 100010
using namespace std;
int main(){
int T;
cin>>T;
int d;
while(T--){
int n;
cin>>n;
if(n==0)
printf("0\n");
else{
d=n*n;
printf("%d\n",d%10000);
}
}
return 0;
}
还要注意题目要求输出的是距离模上10000;