2017网易内推笔试题

题目:有n个奶牛排成一排,每个奶牛拥有一定的苹果数ai,每次操作可以从任一只奶牛手中仅且拿2个两个苹果给另外一只奶牛,输出至少要操作多少次才能使得所有奶牛的苹果数相等,如果不可能达到相等状态,则输出-1.
import java.util.*;
public class Main {
public static void main(String[] args){
Scanner cin = new Scanner(System.in);
while(cin.hasNextLine()){

       int n = Integer.valueOf(cin.nextLine());
       int[] arr = new int[n];
       String[] str = cin.nextLine().split(" ");
       int sum = 0;
       for(int i=0;i<n;i++){
           arr[i] = Integer.valueOf(str[i]);
           sum+=arr[i];
       }
       if(sum%n!=0){
           System.out.println(-1);continue;
       }
       int per = sum/n;
       int count = 0;
       boolean flag = true;
       for(int i=0;i<n;i++){
          int yiDong = Math.abs(arr[i]-per);
          if( yiDong%2!=0){
              System.out.println(-1);
              flag =false;
              break;
          }
          count  = count + yiDong/2;
       }
       if(flag){
           System.out.print(count/2);
       }       
   }

}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值