【蓝桥杯】省赛:分糖果(思维/模拟)

思路

数据很小,直接暴力模拟。

有意思的是一个列表如何当成循环队列写?可以arr[(i+1)%n]让他右边超出时自动回到开头。

code

python 复制代码
import os
import sys

n = int(input())
arr = list(map(int,input().split()))

ans = 0
while 1:
  arr1 = arr.copy()
  for i in range(n):
    arr1[i] = (arr[i] + arr[(i+1)%n])//2
    if arr1[i] % 2 == 1:
      arr1[i] += 1
      ans += 1
  arr = arr1.copy()
  if len(set(arr)) == 1:break
print(ans)
相关推荐
CoderYanger7 小时前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
덕화8 小时前
【面试宝典】线上问题逆向分析1
面试·职场和发展
美团程序员8 小时前
一篇文章教你搞定:”xx 功能如何测试?“常见面试题型!
测试工具·面试·职场和发展·测试用例
墨染点香10 小时前
LeetCode 刷题【172. 阶乘后的零】
算法·leetcode·职场和发展
铭哥的编程日记14 小时前
《斩获字节跳动offer 最详细的面试真题与破解思路》第一期
面试·职场和发展
小白程序员成长日记15 小时前
2025.11.23 力扣每日一题
算法·leetcode·职场和发展
爱学测试的雨果18 小时前
收藏!软件测试面试题
开发语言·面试·职场和发展
川Princess19 小时前
【面试经验】梅赛德斯奔驰X-Seed AI Systems - Autonomous Driving Agent Efficiency二面
面试·职场和发展
编程小Y20 小时前
配置Associated Domains时,需要注意哪些细节?
职场和发展·蓝桥杯