解题思路:

1、定义两个数组 cn[],bf[]一个用来存放每一回合的糖果数,一个用来存放每一回合分出去的糖果

2、用while进行循环

注意事项:
最后的一个小朋友的糖果是第一个小朋友给的,不要都弄成cn[i+1] 会造成超出数组界限
参考代码:


import java.util.Scanner;

public class Main{
   public static void main(String[] args) {
       Scanner scanner = new Scanner(System.in);
       int num = scanner.nextInt();
       int[] cn = new int[num];
       int[] bf = new int[num];
       int count=0;//老师分出去的糖果数
       for (int i = 0; i < num; i++) {
           cn[i] = scanner.nextInt();
       }
       boolean flag = true;
       while (flag) {
           int sum=0;//当小朋友的糖果数都相等的时候 sum==num-1
           for (int i = 0; i < num; i++) {
               bf[i]=cn[i]/2;
               cn[i]=cn[i]/2;
           }
           for (int i = 0; i < num; i++) {
               if (i==num-1){
                   cn[num-1]=cn[num-1]+bf[0];
               }else {
                   cn[i]=cn[i]+bf[i+1];
               }
           }

          for (int i = 0; i < num; i++){
              if (cn[i]%2!=0){
                  cn[i]++;
                  count++;
              }
          }
           for (int i = 1; i < num; i++){
               if (cn[i]==cn[0]){
                   sum++;
               }
           }if (sum==num-1){
               flag=false;
           }
       }
       System.out.println(count);
   }
}

点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论