题目描述
对于给定的一个长度为N的正整数数列Ai,现要将其分成连续的若干段,并且每段和不超过M(可以等于M),问最少能将其分成多少段使得满足要求。
输入格式
第1行包含两个正整数N,M表示了数列Ai的长度与每段和的最大值,第2行包含N个空格隔开的非负整数Ai,如题目所述。
输出格式
一个正整数,输出最少划分的段数。
输入输出样例
输入 #1
5 6
4 2 4 5 1
输出 #1
3
说明/提示
对于20%的数据,有N≤10;
对于40%的数据,有N≤1000;
对于100%的数据,有N≤100000,M≤109,M大于所有数的最小值,Ai之和不超过109。
将数列如下划分:
[4][24][51]
第一段和为4,第2段和为6,第3段和为6均满足和不超过M=6,并可以证明3是最少划分的段数。
思路:
- 分三种情况
- t<m,继续循环
- 但是如果 i 到了最后,cnt也要加一
- t=m,刚好等于m,cnt自增
- t>m,说明已经超过了m,cnt自增,令此时的t等于当前的下标所对应的数值,相当于把当前的数与前一个分离
代码实现:
package qwx.luogu;
import java.util.Scanner;
public class p1181 {
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
int n=scanner.nextInt();
int m=scanner.nextInt();
int []c=new int[n];
int cnt=0;
int t=0;
for(int i = 0; i < n;i++) {
c[i]=scanner.nextInt();
}
for(int i=0;i<n;i++){
t+=c[i];
if (t<m)
{
if(i==n-1)
cnt++;
continue;
}
else if(t==m) {
cnt++;
t=0;
}
else if(t>m){
cnt++;
t=c[i];
continue;
}
}
System.out.println(cnt);
}
}