当前位置: 首页 > news >正文

#题解#牛客:牛牛的构造#DP#构造#

传送门

分析

1.容易发现的一件事,当n,n-1,n-2......2,1排列时是满足条件的(i,j)对最多的n排列

2.我们用递推的想法求每一个n的最大(i,j)对数ans[n]

ans[0] = 0;int pre = 0;int x = 0;for (int i = 1; i <= n; i++){for (; i - (1 << x) > 0; x++)pre++;ans[i] = ans[i - 1] + pre;
  1. 容易发现的另一件事,若某段单调递增,那么这段内没有符合要求的 ( i , j ) 对。

更一般地:若a[i+1]是[1,i+1]的最大前缀值,那么任意 ( j , i + 1 )不符合要求(j<i+1)

  1. 根据3. 我们有了以下的构造想法

若k恰好是某个ans[i],那么前i个数是i,i-1,i-2,.......,2,1,后面的数是i+1,i+2,.......,n-1,n即可

若k夹在ans[i-1]与ans[i]之间,那么后n-i个数是i+1,i+2,.......,n-1,n。前i个数则是在i-1,i-2,......,3,2,1中挑选一个合适的位置插入i即可。

  1. 考虑如何选择插入位置:设t=k-ans[i-1] , top=log2(i).

容易证明只需将 i 插入到i-2^(top-t+1)的前面一个数即可。

代码实现

#include<bits/stdc++.h>
using namespace std;
const int N = 1e6+10;
int ans[N];
int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n, k;cin >> n >> k;bool flag = 1;ans[0] = 0;int pre = 0;int x = 0;for (int i = 1; i <= n; i++){for (; i - (1 << x) > 0; x++)pre++;ans[i] = ans[i - 1] + pre;if (ans[i] == k ){flag = 0;for (int j = i; j >= 1; j--)cout << j << " ";for (int j = i + 1; j <= n; j++)cout << j << " ";break;}else if (ans[i] > k && ans[i - 1] < k){flag = 0;int t = k - ans[i - 1] - 1;int zhishu = log2(i);t = zhishu - t;t = (1 << t);t = i - t ;for (int j = i - 1; j >= 1; j--){if (j == t )cout << i << " " << j << " ";elsecout << j << " ";}for (int j = i + 1; j <= n; j++)cout << j << " ";break;}}if (flag)cout << -1;return 0;
}
http://www.jsqmd.com/news/38704/

相关文章:

  • Machine Learning - SVM Part 2: The Radial Kernel
  • 2025-11-12 ZYZ28-NOIP-aoao round 2 hetao1733837的record
  • 2025/11/12
  • redis stream介绍
  • Java 线性表、栈、队列和优先队列
  • 2025/11/11
  • 植物大战僵尸修改器下载教程:图文详解与实用技巧
  • 微服务——注册中心
  • 【深度学习计算机视觉】13:实战Kaggle比赛:图像分类 (CIFAR-10) - 指南
  • fabricjs 整合 vue3-sketch-ruler 实现标尺功能
  • 2025年真空耙式干燥机定做厂家权威推荐榜单:真空单锥螺带干燥机/沸腾床干燥机/闪蒸干燥机源头厂家精选
  • 基础查找算法(三)二分查找
  • 2025年软像套电缆订做厂家权威推荐榜单:补偿电缆/矿物质电缆/电力电缆源头厂家精选
  • 2025年济南统招专升本学校权威推荐榜单:专升本机构报名/全日制专升本/专升本考试培训学校精选
  • 一些水题
  • (3)Bug篇 - 详解
  • 西林瓶灌装轧盖机:黔东南折旧年限与成本解析
  • list对象 集合 和 String 互转
  • 碎碎念(二四)
  • 高精度除法模板(p1480)
  • 如何完成一个简单的rust WebAssembly调用
  • 焊接工业机器人节气装置
  • 详细介绍:考研408--组成原理--day1
  • 深入解析:海尔 Haier Master 智能家居网关安装 Home Assistant 实践指南
  • 枣庄西林瓶灌装轧盖机:SIP灭菌快,自动冷却高效
  • 【Nano Banana超详细教程】AI绘图神器Gemini 2.5实测:一键生成神图!
  • 已完成今日基础缩索大学习
  • 配置ElactisSearch跨域
  • 西林瓶粉末灌装机:塔城培训服务免费提供
  • Ubuntu设置中文智能拼音输入法