321
社区成员




书是人类进步的阶梯。 小艺每周因为工作的原因会选择性的每天多读几页或者少读几页。 小艺想知道一本n页的书她会在周几读完。
第一行输入n(1<=n<=1000); 第二行输入7个整数,分别表示周一~周日的读书页数p(0<=p<=1000)。(不考虑7个整数都为0的情况)
求出每天累计读多少,然后直接计算即可。
n = int(input())
arr = list(map(int,input().split()))
l = (n - 1) % sum(arr)
print(min([i if l < sum(arr[:i + 1]) else 7 for i,v in enumerate(arr)]) + 1)
用求余的方式计算,可以确定计算多少次,如果用循环方式去做,如果n特别大。。。那就很没效率了
n = parseInt(readline())
arr = readline().split(' ').map(x => parseInt(x))
u = Array.from(arr).map((x,y) => eval(arr.filter((i,j) => j <= y).join('+')))
l = (n - 1) % u[6]
print(Array.from(u).map((x,y) => l < x ? y : 7).sort((x,y) => x > y ? 1 : -1)[0] + 1)
弱类型看着就比强类型代码少。。。。
using System;
using System.Collections;
using System.Collections.Generic;
class Program {
public static void Main() {
int n = int.Parse(Console.ReadLine().Trim());
string[] arr = Console.ReadLine().Split(" ");
List<int> d = new List<int>();
for (int i = 0 ; i < 7 ; i ++){
d.Add(int.Parse(arr[i]) + (d.Count > 0 ? d[d.Count - 1] : 0));
}
n %= d[6];
int a = 7;
for (int i = 6 ; i > -1 ; i --){
if (d[i] >= n){
a = i + 1;
}
}
Console.WriteLine(a.ToString());
}
}