洛谷 P2669 [NOIP2015 普及组] 金币

本文由Jzwalliser原创,发布在CSDN平台上,遵循CC 4.0 BY-SA协议。
因此,若需转载/引用本文,请注明作者并附原文链接,且禁止删除/修改本段文字。
违者必究,谢谢配合。
个人主页:blog.csdn.net/jzwalliser

题目

洛谷 P2669 [NOIP2015 普及组] 金币

[NOIP2015 普及组] 金币

题目背景

NOIP2015 普及组 T1

题目描述

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

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

输入格式

一个正整数 k k k,表示发放金币的天数。

输出格式

一个正整数,即骑士收到的金币数。

样例 #1

样例输入 #1
6
样例输出 #1
14

样例 #2

样例输入 #2
1000
样例输出 #2
29820

提示

【样例 1 说明】

骑士第一天收到一枚金币;第二天和第三天,每天收到两枚金币;第四、五、六天,每天收到三枚金币。因此一共收到 1 + 2 + 2 + 3 + 3 + 3 = 14 1+2+2+3+3+3=14 1+2+2+3+3+3=14 枚金币。

对于 100 % 100\% 100% 的数据, 1 ≤ k ≤ 1 0 4 1\le k\le 10^4 1k104

想法

可以先观察一下这个数列:
1 , 2 , 2 , 3 , 3 , 3 , 4 , 4 , 4 , 4 , 5 , 5 , 5 , 5 , 5 , 6 , 6 , 6 , … 1,2,2,3,3,3,4,4,4,4,5,5,5,5,5,6,6,6,\dots 1,2,2,3,3,3,4,4,4,4,5,5,5,5,5,6,6,6,
能得出来什么规律呢?稍稍推理一下,我们就可以得到以下公式:
假设第 n n n天会获取 m m m个金币,则
m n = 1 + ⌊ 8 n − 7 ⌋ 2 m_n=\frac{1+\lfloor \sqrt{8n - 7} \rfloor}{2} mn=21+8n7
那么,总的金币个数为 ∑ i = 1 n m i \sum_{i=1}^n m_i i=1nmi
得出规律后,时间复杂度被压缩到了 O ( n ) O(n) O(n),不至于超时了。
至于推理的过程,如果不懂可以看这里:由1,2,2,3,3,3,4,4,4,4……推出公式

实现

  1. 用刚才得出的规律,写一个函数。
  2. 算出每一天拿到的金币数,将它们累加起来。
  3. 最后别忘记输出啊。

题解

C++

#include<bits/stdc++.h>
using namespace std;

int coin(int n){ //计算第n天拿到的金币数
	return (1 + sqrt(8 * n - 7)) / 2; //套公式
}

int main(){
	int n,total = 0;
	cin >> n; //输入
	for(int i = 1;i <= n;i++){
		total += coin(i); //调用函数,累加金币个数
	}
	cout << total; //输出
	return 0;
}

Python

import math
def coin(n): #计算第n天拿到的金币数
	return int((1 + int(math.sqrt(8 * n - 7))) / 2) #套公式

total = 0
n = int(input()) #输入
for i in range(1,n + 1):
	total += coin(i) #调用函数,累加金币个数

print(total) #输出

难度

难度:★★☆☆☆
这道题主要是推公式有点费解。公式推出来之后,题目迎刃而解,而且代码简洁。

结尾

你是怎么想的?欢迎留言啊!我们下期再见!(˵¯͒〰¯͒˵)

  • 48
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值