1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

解题思路

本题要求两名管理员交替从当前“存活”的书中挑选:

  • 小张每次选全局最轻(若并列取最左)
  • 小李每次选全局最重(若并列取最右) 然后以该书为中心,向左右各扩展至多 k 本,一并移除。这个“左右”始终是相对当前尚未被移除的相邻关系。

要高效实现,需要同时解决两个核心操作:

P3899.第2题-整理书籍

    1000ms Tried: 22 Accepted: 10 Difficulty: 6 所属公司 : 京东
    算法与标签>模拟

题目内容

图书馆有 nnn 本书横向排成一排,从左到右编号为 111 到 nnn ,每本书的重量为 aia_iai​ 千克。图书管理员小张和小李轮流整理这些书籍,规则如下:

首先是小张整理,小张的策略是找到当前书架上最轻的一本书(如果有多个重量相同,则选择最左侧的那本),然后搬走这本书以及它左侧的 kkk 本书(如果左侧不足 kkk 本,则搬走左侧全部)和它右侧的 kkk 本书(如果右侧不足 kkk 本,则搬走右侧全部)。

然后是小李整理,小李的策略是找到当前书架上最重的一本书(如果有多个重量相同,则选择最右侧的那本),然后搬走这本书以及它左侧的 kkk 本书和右侧的 kkk 本书(不足时的处理情况同上)。

两人轮流整理,直到所有书籍都被搬走。图书馆馆长要记录工作情况,他想知道最后两人分别搬走了哪些书籍。

输入描述

第一行为两个整数 n(1≤n≤100000)n(1≤n≤100000)n(1≤n≤100000) 和 k(0≤k≤n)k(0≤k≤n)k(0≤k≤n) ,分别表示书籍的总数量和每次搬书时向两侧扩展的书籍数量。

第二行为 nnn 个空格隔开的整数,其中第 iii 个数 ai(1≤ai≤1000)a_i(1≤a_i≤1000)ai​(1≤ai​≤1000) 表示第 iii 本书的重量。

输出描述

输出的第一行为小张搬走的书籍编号,按升序排列。

输出的第二行为小李搬走的书籍编号,按升序排列。

数据保证每人都至少搬走了一本书。

样例1

输入

10 2
3 1 4 1 5 9 2 6 5 3

输出

1 2 3 4 9 10
5 6 7 8

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 1, 59ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?