解题思路:
注意事项:
注意 判读数组每个值是否相等的写法
int b=0;
for (int i = 0; i < n; i++) {
if (arr[i] != arr[0]) {
b++;
}
}
if (b == 0) {
System.out.println(count);
a=false;//相等就把条件值改为false,跳出循环
}
参考代码:
import java.util.Scanner;
public class 分糖果 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();//定义分糖人数
int count = 0;//定义补糖计数
boolean a=true;//定义循环条件初始值
int arr[] = new int[n];//定义分糖数据存储池
int text[] = new int[n];//定义辅助数据池
for (int i = 0; i < n; i++) {
arr[i] = scanner.nextInt();
}
while (a) {
for (int i = 0; i < n; i++) {
arr[i] = arr[i] / 2;//每人分出一半
text[i] = arr[i];//将分出的糖存入辅助池
}
arr[0] = text[0] + text[n - 1];//最后一人分给了第一个人
for (int i = 1; i < n; i++) {
arr[i] = text[i] + text[i - 1];//其他人都是分给了自己的下一个人
}
for (int i = 0; i < n; i++) {
if (arr[i] % 2 != 0) {//判断是不是偶数
arr[i] = arr[i] + 1;//如果不是偶数,补一个糖果
count++;//补糖计数加一
}
}
//判断每人的糖果数量是否相等
int b=0;
for (int i = 0; i < n; i++) {
if (arr[i] != arr[0]) {
b++;
}
}
if (b == 0) {
System.out.println(count);
a=false;//相等就把条件值改为false,跳出循环
}
}
}
}
//给个好评吧。
0.0分
0 人评分
C二级辅导-公约公倍 (C语言代码)浏览:823 |
2006年春浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:905 |
分糖果 (C++代码)浏览:865 |
C语言训练-列出最简真分数序列* (C语言代码)浏览:506 |
C语言程序设计教程(第三版)课后习题10.1 (Java代码)浏览:1447 |
C语言程序设计教程(第三版)课后习题8.3 (C语言代码)浏览:422 |
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:520 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:560 |
用筛法求之N内的素数。 (C语言代码)浏览:650 |
数对 (C语言代码)浏览:702 |