宋哥哥


私信TA

用户名:630591905

访问量:8286

签 名:

等  级
排  名 843
经  验 3634
参赛次数 3
文章发表 9
年  龄 0
在职情况 学生
学  校 迦南魔法学院
专  业

  自我简介:


解题思路:比如输入4  10  20  30  40

102030

40

5101520
15253525

     第二行arr[i]数组变为一半,第三行,除最后一列,每一列等于右边一列加上它自身。最后一列为第一行加上最后一列本身。
注意事项:注意把arr[0]要存起来哟,不然arr[0]会变

参考代码:

                Scanner in=new Scanner(System.in);
		
		int n=in.nextInt();
		int arr[]=new int[n];
		
		
		for(int i=0;i<n;i++)
		{
			arr[i]=in.nextInt();
		}
		int flag=0;                  //判断数组是否全部相等
		int count=0;                  //计时器
		while(flag==0)
		{
			flag=1;
			
			for(int i=0;i<n;i++)      //数组全部除2
			{
				arr[i]=arr[i]/2;
			}
			int t=arr[0];             //把数组第一项存起来,不然第一项会变
			for(int i=0;i<n;i++)      //让小朋友把橘子给旁边的人
			{
				if(i+1<n)
				arr[i]=arr[i]+arr[i+1];
				
				if(i==n-1)
				{
					arr[i]=arr[i]+t;
				}
				
			}
			
			
			for(int i=0;i<n;i++)       //判断,如果橘子是奇数,就加1,count拿来记数
			{
				if(arr[i]%2!=0)
				{
					arr[i]+=1;
					count++;
					
				}
				
			}
			
			for(int i=0;i+1<n;i++)     //判断数组是否全部相等,如果有不等的,就把flag置为0
			{
				if(arr[i]!=arr[i+1])
				{
					flag=0;
				}
			}
			
			if(flag==1)            //flag此时还为1的话,那么表示数组就全部相等了,就输出计数器
			{
				System.out.println(count);
			}
			
			
			
		}
	}
}		
		


 

0.0分

7 人评分

  评论区

大佬牛逼
2021-10-02 21:22:52
总得来看,分三步:给一半糖,奇数补充并计数,判断是否相等。我感觉判断是否相等是不是应该放在第一步,因为如果一开始就是 10 10 10 10,那如果相等就可以退出。
2020-06-10 10:09:26
哥你能讲清楚点吗?不是很懂啊
2019-09-02 14:27:24
  • «
  • 1
  • »