码迷,mamicode.com
首页 > 其他好文 > 详细

【模拟练习】[一]

时间:2017-06-27 23:30:13      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:put   解决   else   data   onclick   技术   分享   name   class   

1684: 金币


 

时间限制: 1 Sec  内存限制: 128 MB
提交: 143  解决: 97
[提交][状态][讨论版]

题目描述

国王将金币作为工资,发放给忠诚的骑士。第一天,骑士收到一枚金币;之后两天(第二天和第三天) ,每天收到两枚金币;之后三天(第四、五、六天) ,每天收到三枚金币;之后四天(第七、八、九、十天) ,每天收到四枚金币……;这种工资发放模式会一直这样延续下去:当连续 N 天每天收到 N 枚金币后,骑士会在之后的连续 N+1 天里,每天收到 N+1 枚金币。

请计算在前 K 天里,骑士一共获得了多少金币。

输入

输入文件名为 coin.in。
输入文件只有 1 行,包含一个正整数 K,表示发放金币的天数。

输出

输出文件名为 coin.out。
输出文件只有 1 行,包含一个正整数,即骑士收到的金币数。

样例输入

6

样例输出

14

提示

 

【输入输出样例 1 说明】

骑士第一天收到一枚金币; 第二天和第三天, 每天收到两枚金币; 第四、 五、 六天,

每天收到三枚金币。因此一共收到 1+2+2+3+3+3=14 枚金币。

【输入输出样例 2】

coin.in 

1000



coin.out

29820

见选手目录下的 coin/coin2.in 和 coin/coin2.ans。

【数据说明】

对于 100%的数据,1 ≤ K ≤ 10,000。

 

来源

NOIP2015普及组


技术分享
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
using namespace std;
int n;
int ans;
int main()
{
    cin>>n;
    int tian=1;
    while(n>0)
    {
        n-=tian;
        if(n<0)ans+=tian*(tian+n);
        else ans+=tian*tian;
        tian++;
    }
    cout<<ans;
    puts("");
    return 0;
}
View Code

//ATT:只有等于0才是假 其他都是真的 

 

 


【模拟练习】[一]

标签:put   解决   else   data   onclick   技术   分享   name   class   

原文地址:http://www.cnblogs.com/gc812/p/7087411.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!