牛客网编程练习之编程马拉松:砌墙

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了牛客网编程练习之编程马拉松:砌墙相关的知识,希望对你有一定的参考价值。

image

image

 

 

思路其实很简单,无论再少的步骤,至少要能把矮的堆到平均高度,所以只求 sum(avg - (<avg))即可。

 

AC代码:

import java.util.Arrays;
import java.util.Scanner;

/**
 * @author CC11001100
 */
public class Main {

	public static void main(String[] args) {

		Scanner sc = new Scanner(System.in);

		while (sc.hasNextInt()){
			int n = sc.nextInt();
			int[] stacks = new int[n];
			for (int i = 0; i < n; i++) {
				stacks[i] = sc.nextInt();
			}

			System.out.println(resolve(stacks));
		}

	}

	private static int resolve(int[] n) {
		int avg = (int) Arrays.stream(n).average().orElse(0);
		return Arrays.stream(n).map(x -> x >= avg ? 0 : avg - x).sum();
	}

}

 

 

题目来源: https://www.nowcoder.com/practice/f1b67248244c4226a5289c993bc28128?tpId=3&tqId=10914&tPage=1&rp=&ru=/ta/hackathon&qru=/ta/hackathon/question-ranking

以上是关于牛客网编程练习之编程马拉松:砌墙的主要内容,如果未能解决你的问题,请参考以下文章

牛客网编程练习之编程马拉松:数据库连接池

牛客网编程练习之编程马拉松:红与黑

牛客网编程练习之网易2017校招题:下厨房

牛客网编程练习之游戏任务标记

牛客网编程练习之解救小易

手机牛客在线编程入口在哪