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

编程分苹果问题_分析解决问题有关总结分苹果问题分析及程序*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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • u8和u16是什么意思_u8在哪里声明的

    u8和u16是什么意思_u8在哪里声明的unsignedint32(C语言标准表达方法)2.uint32_t;3.u32;这三种表达式是同一个意思,只是在不用的版本当中,为了兼容旧版本而出现这么多的表达方式。但不管怎么变化,都是基于标准c。主要用处是为了在定义数据类型的时候少写几个符号。unsignedchar=uint8_t=u8unsignedshortint=…

    2022年10月15日
    2
  • java实现发送手机验证码功能

    java实现发送手机验证码功能1.进入秒嘀科技(http://www.miaodiyun.com/),注册一个账号2.注册好之后,点击用户中心->账户管理,就会进入如下界面(顺便提一下,新注册的用户,平台会免费赠送你10元,足够大家学习和使用了,所以不用担心需要充钱)你需要做的就是获取你自己的ACCOUNTSID和AUTHTOKEN3.点击用户中心->认证,进行企…

    2022年7月21日
    19
  • 数据结构与算法(3)

    数据结构与算法(3)

    2021年11月12日
    51
  • java.lang.RuntimeException: Can not toast on a thread that has not called Looper.prepare()终极解决方案

    java.lang.RuntimeException: Can not toast on a thread that has not called Looper.prepare()终极解决方案使用runOnUiThread方法,不使用Looper。

    2022年7月18日
    16
  • 一些好玩的代码_100个简单代码

    一些好玩的代码_100个简单代码1.让网页的图片都漂动起来将以下代码复制到地址框,回车。有些浏览器会把"javaScript"过滤掉,可手动添加"javaScript"2.一行代码让电脑

    2022年8月4日
    6
  • CPU流水线指令「建议收藏」

    CPU流水线指令「建议收藏」CPU流水线指令执行示意图增加流水线深度,其实是有性能成本的。每增加一级流水线,就要多一级写入到流水线寄存器的操作。单纯地增加流水线级数,不仅不能提升性能,反而会有更多的overhead的开销。所以,设计合理的流水线级数也是现代CPU中非常重要的一点。我们其实并不能简单地通过CPU的主频,就来衡量CPU乃至计算机整机的性能。因为不同的CPU实际的体系架构和实现都不一样。同样的CPU主…

    2022年8月20日
    13

发表回复

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

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