V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
penguinhlxhands
V2EX  ›  Python

个算法题想了好久没思路,求指点

  •  1
     
  •   penguinhlxhands · 2020-07-27 17:18:54 +08:00 · 1572 次点击
    这是一个创建于 1580 天前的主题,其中的信息可能已经有所发展或是发生改变。

    射击训练,需要给每个士兵发子弹,发子弹的个数规则是根据士兵的训练成绩给定的,传入士兵的训练成绩,要求相邻士兵中,成绩好的士兵的子弹数必须更多,每个士兵至少分配一个子弹。

    输入描述:

    输入每个士兵的训练成绩,如 1,2,3,代表 3 位士兵的成绩分别为 1,2,3

    输出描述:

    最少分配的子弹数

    示例 1:

    输入:1,2,2

    输出:4

    AlisaDestiny
        1
    AlisaDestiny  
       2020-07-27 21:35:49 +08:00   ❤️ 2
    这个就是求数据的极值点,最小值处的值都是 1,最大值处的值是 n = max(到左极值距离,到右极值距离),距离远的一侧从最小值处到最大值处需要的子弹数是 sum(1..n),另一侧是 sum(1..到极大值距离-1)
    AlisaDestiny
        2
    AlisaDestiny  
       2020-07-27 21:38:38 +08:00
    需要的子弹总数就是将各个区段的和值相加。
    nthhdy
        3
    nthhdy  
       2020-07-27 22:00:11 +08:00
    如果相邻的分数相同,应该是没有约束的
    warush
        4
    warush  
       2020-07-28 01:51:24 +08:00 via iPhone   ❤️ 1
    这不就是 leetcode 上的 candy,从左往右便利一下给最低的子弹,然后再从有往左边遍历一遍
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2767 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 07:50 · PVG 15:50 · LAX 23:50 · JFK 02:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.