题目:
国王将金币作为工资,发放给忠诚的骑士。第一天,骑士收到一枚金币;之后两天(第二天和第三天),每天收到两枚金币;之后三天(第四、五、六天),每天收到三枚金币;之后四天(第七、八、九、十天),每天收到四枚金币……;这种工资发放模式会一直这样延续下去:当连续 n 天每天收到 n 枚金币后,骑士会在之后的连续 n+1 天里,每天收到 n+1枚金币。
请计算在前 k天里,骑士一共获得了多少金币。
输入:一个正整数k
要求:计算其实在前k天里一共获得了多少金币
提示:可以用简简单单的while循环结构
上图
k = int(input()) #输入一个正整数k
a = 1
c = 0
while k > 0:
b = a * a
if k != 0 and k < a: #非常基础的条件语句判断
c = c + k * a
k = k - a
else:
c = c + b
k = k - a
a = a + 1
print(c) #打印结果
思路:先输入一个正整数k,创建变量a(计算已过去了几天),创建变量c(计算金币总数),在k大于0时循环,创建变量b(当还有剩余天数时获得的金币数,会逐次递增),if条件语句判断(如果k不等于0且k小于a则执行代码),else(除k != 0 and k < a之外的情况则执行代码),a每次循环将a+1赋值给a(同a+=1),循环外最后打印结果