编程分苹果问题_分析解决问题有关总结

编程分苹果问题_分析解决问题有关总结分苹果问题分析及程序*n只奶牛坐在一排,每个奶牛拥有ai个苹果,*现在你要在它们之间转移苹果,使得最后所有奶牛拥有的苹果数都相同*,每一次,你只能从一只奶牛身上拿走恰好两个苹果到另一个奶牛上,*问最少需要移动多少次可以平分苹果,如果方案不存在输出-1。

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

 /*

 * n 只奶牛坐在一排,每个奶牛拥有 ai 个苹果

 * 现在你要在它们之间转移苹果,使得最后所有奶牛拥有的苹果数都相同

 * ,每一次,你只能从一只奶牛身上拿走恰好两个苹果到另一个奶牛上,

 * 问最少需要移动多少次可以平分苹果,如果方案不存在输出 -1。

输入描述:

每个输入包含一个测试用例。

每个测试用例的第一行包含一个整数 n(1 <= n <= 100),

接下来的一行包含 n 个整数 ai(1 <= ai <= 100)。

输出描述:

输出一行表示最少需要移动多少次可以平分苹果,如果方案不存在则输出 -1。

示例1

输入

4

7 15 9 5

输出

3

 */ 

//题目来源互联网.

public class FenApple {

public static void main(String[] args) {

//新建输入流对象
Scanner sc = new Scanner(System.in);

//循环输入
while (sc.hasNext()) {

//输入n
int n = sc.nextInt();

//输入n个数字 并赋值给数组
int[] arr = new int[n];
for (int i = 0; i < arr.length; i++) {

arr[i] = sc.nextInt();
}

//如果苹果最终无法被n整除,则无法平分
int sum = 0;
for (int i : arr) {

sum += i;
}
if (sum % n == 0) {

int avg = sum / n;
int index = 0;

//如果可以平分,每次只能换走两个苹果 ,所以如果所有的苹果数在减去平均苹果数后无法被二整除 则同样无法做到分配,

//定义计数器,如果有不能被二整除的情况则自加(也可以使用Boolean类型变量)

int count = 0;
for (int i = 0; i < arr.length; i++) {

if ((arr[i] – avg) % 2 != 0) {

count++;
}
if (arr[i] > avg) {

index += (arr[i] – avg) / 2;
}

}

//判断计数器 并输出
if (count == 0) {

System.out.println(index);
} else {

System.out.println(-1);
}
} else {

System.out.println(-1);
}
}
}
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182967.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java接口是什么意思_JAVA接口

    Java接口是什么意思_JAVA接口下看下接口定义@FunctionalInterfacepublicinterfaceSupplier<T>{/***Getsaresult.**@returnaresult*/Tget();}supplier英[səˈplaɪə(r)]美[səˈplaɪər]…

    2022年10月23日
    0
  • furture_南京future

    furture_南京future我想,还是不知道未来比较好!揭开神秘的同时也扼杀了希望,所谓预测未来就是创造那个未来,意味着我们放弃了主宰未来的权利!

    2022年8月3日
    3
  • 带通滤波器幅频特性曲线图_滤波器知识,你所要的,都在这里

    带通滤波器幅频特性曲线图_滤波器知识,你所要的,都在这里滤波器是一种选频装置,可以使信号中特定的频率成分通过,而极大地衰减其它频率成分。一、概述1、定义凡是可以使信号中特定的频率成分通过,而极大地衰减或抑制其他频率成分的装置或系统都称之为滤波器,相当于频率“筛子”。2、分类频率通带:能通过滤波器的频率范围。频率阻带:被滤波器抑制或极大地衰减的信号频率范围。截止频率:通带与阻带的交界点。2)按物理原理分:机械式、电路式;按处理信号分:模拟、数字3、滤波…

    2022年6月1日
    118
  • RewriteRule指令[通俗易懂]

    RewriteRule指令[通俗易懂]作为RewriteRule指令的第三个参数。Flags是一个包含以逗号分隔的下列标记的列表: ‘last|L'(最后一个规则last)立即停止重写操作,并不再应用其他重写规则。它对应于Perl中的last命令或C语言中的break命令。这个标记可以阻止当前已被重写的URL为其后继的规则所重写。举例,使用它可以重写根路径的URL(‘/’)为实际存在的URL,比如,’/e/w

    2022年5月14日
    32
  • 安防监控知识整理「建议收藏」

    安防监控知识整理「建议收藏」一、常见品牌海康威视大华天地伟业二、协议onvifrtsp三、其它点1、厂家接入自家NVR一般使用私有协议,NVR接入自家平台也使用私有协议;但不同的厂商私有协议是不同的,各厂家IPC接入NVR需要一个标准的协议,onvif协议。而规范各厂家IPC接入平台需要GB28181协议。2、GB28181目前不支持H.265…

    2022年6月28日
    28
  • 解决idea一直处于Process Running问题

    解决idea一直处于Process Running问题

    2021年6月11日
    117

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号