第十题:金币

题目描述

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

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

输入描述

输入只有 1 行,包含一个正整数 K (1≤K≤104),表示发放金币的天数。

输出描述

输出只有 1 行,包含一个正整数,即骑士收到的金币数。

输入输出样例

示例 1

输入

复制代码
6

输出

复制代码
14

示例 2

输入

复制代码
1000

输出

复制代码
29820

运行限制

  • 最大运行时间:1s

  • 最大运行内存: 256M

分析:(双层循环)

将给予相同硬币数的视为同一类,然后在每个相同硬币数类中包含的天数中进行处理。

代码:

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char *argv[]) {
	int K,N = 0;//N为叠加的天数
	int count = 0;
	scanf("%d",&K);
	for(int i = 1; i<10001; i++) {//将给予相同硬币数的视为同一类 
		for(int j = 0; j<i; j++) {//表示每个相同硬币类中包含多少天 
			N++;
			if(N > K)
				goto pri;
			count+=i;
		}
	}
pri:
	printf("%d",count);
	return 0;
}
相关推荐
hnjzsyjyj18 小时前
东方博宜OJ 2190:树的重心 ← 邻接表 or 链式前向星
数据结构·链式前向星·树的重心
yaoh.wang20 小时前
力扣(LeetCode) 13: 罗马数字转整数 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
ChoSeitaku20 小时前
NO15数据结构选择题考点|线性表|栈和队列|串
数据结构
T1ssy20 小时前
布隆过滤器:用概率换空间的奇妙数据结构
算法·哈希算法
hetao173383721 小时前
2025-12-12~14 hetao1733837的刷题笔记
数据结构·c++·笔记·算法
一直都在57221 小时前
数据结构入门:时间复杂度与排序和查找
数据结构
鲨莎分不晴21 小时前
强化学习第五课 —— A2C & A3C:并行化是如何杀死经验回放
网络·算法·机器学习
搞科研的小刘选手1 天前
【ISSN/ISBN双刊号】第三届电力电子与人工智能国际学术会议(PEAI 2026)
图像处理·人工智能·算法·电力电子·学术会议
拉姆哥的小屋1 天前
从混沌到秩序:条件扩散模型在图像转换中的哲学与技术革命
人工智能·算法·机器学习
Sammyyyyy1 天前
DeepSeek v3.2 正式发布,对标 GPT-5
开发语言·人工智能·gpt·算法·servbay