题解 | #牛群放牧顺序#
牛群放牧顺序
https://www.nowcoder.com/practice/69f5f2d04d1c41df8d4e0691f6ef6935
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param ratings int整型一维数组
* @return int整型
*/
public int min_pasture_time (int[] ratings) {
// write code here
int[] res = new int[ratings.length];
res[0] = 1;
//左边小就赋值左边+1,否则赋值1(因为最小放牧次数为1)
for (int i = 1; i < ratings.length; i++) {
res[i] = ratings[i] > ratings[i - 1] ? res[i - 1] + 1 : 1;
}
//计算最小放牧次数,因为遍历从倒数第二个元素开始,所以sum初始化倒数第一个元素
int sum = res[ratings.length - 1];
//右边比自己大就赋值右边+1,否则不动
for (int i = ratings.length - 2; i >= 0; i--) {
if(ratings[i] > ratings[i + 1])
res[i] = res[i + 1] + 1;
sum += res[i];
}
return sum;
}
}
查看19道真题和解析