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分析
会员专享
请先登录,登录后可使用今日免费解锁; 开通会员,或 购买 该题目所属题库(阿里系机考题库) ,可解锁完整内容。
购买题库 开通会员

解题思路

题目要求构造一个 1∼n1 \sim n1∼n 的排列,使逆序对数量恰好为 kkk。

一个长度为 nnn 的排列最多有:

n(n−1)2\frac{n(n-1)}{2} 2n(n−1)​

P4949.第1题-逆序对排列构造

    1000ms Tried: 0 Accepted: 0 Difficulty: 4 所属公司 : 阿里
    算法与标签>构造

题目内容

给定两个整数 n,kn,kn,k。请你构造一个长度为 nnn 的排列,使得它的逆序对数量恰好等于 kkk。

排列指用 1,2,…,n1,2,\dots,n1,2,…,n 这 nnn 个数各用一次、按任意顺序组成的数组;数组中没有重复数字,也没有超出 1∼n1 \sim n1∼n 的数字。

逆序对:在排列中,选择一对下标 i<ji < ji<j,如果前面的数比后面的数大(即 ai>aja_i > a_jai​>aj​),那么这对就算一个逆序对。题目要求排列中的所有这样的对数之和为 kkk。

输入描述

每个测试文件包含多组测试数据。第一行输入一个整数 TTT(1≤T≤2×1051 \le T \le 2 \times 10^51≤T≤2×105),表示测试数据组数。 接下来 TTT 行,每行输入两个整数 n,kn,kn,k(1≤n≤2×1051 \le n \le 2 \times 10^51≤n≤2×105;0≤k≤n(n−1)20 \le k \le \frac{n(n-1)}{2}0≤k≤2n(n−1)​)。 除此之外,保证单个测试文件内所有数据的 nnn 之和不超过 2×1052 \times 10^52×105。

输出描述

对于每组测试数据,输出一行,包含 nnn 个整数,表示任意一个满足要求的排列。若存在多种答案,输出任意一种均可。

样例1

输入

3
3 0
3 2
5 7

输出

1 2 3
3 1 2
5 4 1 2 3

说明

  • 第一组:[1,2,3][1,2,3][1,2,3] 逆序对数是 000。
  • 第二组:[3,1,2][3,1,2][3,1,2] 中的逆序对只有 (3,1)(3,1)(3,1) 和 (3,2)(3,2)(3,2) 两对,总数是 222。
  • 第三组:[5,4,1,2,3][5,4,1,2,3][5,4,1,2,3] 中,555 对后面 4,1,2,34,1,2,34,1,2,3 贡献 444 个逆序对,444 对后面 1,2,31,2,31,2,3 贡献 333 个逆序对,总共 4+3=74 + 3 = 74+3=7 个,等于 kkk。

登录后即可使用 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 0, 38ms
    3. Powered by Hydro v5.0.0-beta.18 Community

    Don't have an account?

    By signing up a CodeFun2000 universal account, you can submit code and join discussions in all online judging services provided by us.

    Sign Up Now
    CLOSE

    SIGN IN

    Using your CodeFun2000 universal account

    Login with Wechat
    Forgot password or username?