序列(seq)

题目描述

给定 N,A,BN,A,B,构造一个长度为 NN 的排列,使得:

排列长度为 N;

最长上升子序列长度为 A;

最长下降子序列长度为 B。

我们有 SPJ,有解任意给出一组,否则说明无解。

输入

第一行一个整数 TT (1≤T≤101≤T≤10), 表示数据组数.

接下来 T 行,每行三个正整数 N、A、B。

输出

对每组数据:

如果有解,输出两行,第一行一个字符串 Yes,接下来一行 N 个整数,表示排列。

否则, 输出一行一个字符串 No。

样例输入

3
4 2 2
4 4 1
4 3 3

样例输出

Yes
3 4 1 2
Yes
1 2 3 4
No

提示

数据范围和子任务

对于全部的测试数据,保证 T≤10,N≤105,∑N≤2×105T≤10,N≤105,∑N≤2×105

子任务 1(20 分):N≤5N≤5 .

子任务 2(30 分):每组数据均满足 N=A×BN=A×B .

子任务 3(20 分):B≤2B≤2 .

子任务 4(30 分):无特殊限制


solution

先考虑a*b=n的情况怎么做:连续构造a段下降的b

比如 n=6 a=3 b=2

->      2 1 4 3 6 5

那么如果a>n/b 呢

就把某些段改成升序的

由于每一段之间互不影响,所以这不会改变b的答案

那么n!=a*b 也只是多了一段小段的而已

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define maxn 100005
using namespace std;
int T,n,a,b,ans[maxn],num[maxn];
void init(){
for(int i=1;i<=n;i++)ans[i]=num[i]=0;
}
int main()
{
freopen("seq.in","r",stdin);
freopen("seq.out","w",stdout);
cin>>T;
while(T--){
scanf("%d%d%d",&n,&a,&b);init();
if(a+b>n+1){puts("No");continue;}
for(int i=1;i<=n;i+=b){
int top=i+b-1;top=min(top,n);num[i]=top-i+1;
for(int j=top,x=0;j>=i;j--,x++)ans[j]=i+x;
}
int tmp=n/b;if(n%b)tmp++;
if(tmp>a){puts("No");continue;}
int tp=a-tmp,i=b+1;
while(tp){
if(tp>=num[i]-1){
for(int j=i;j<=i+num[i]-1;j++)ans[j]=j;
tp-=num[i]-1;i=i+b;
}
else {
for(int j=i;j<=i+tp-1;j++)ans[j]=j;
for(int j=i+num[i]-1,x=tp;j>=i+tp;j--,x++)ans[j]=i+x;
tp=0;
}
}
puts("Yes");
for(int i=1;i<=n;i++)cout<<ans[i]<<' ';cout<<endl;
}
return 0;
}

序列(seq)的更多相关文章

  1. BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 5504  Solved: 1937[Submit ...

  2. 【双标记线段树】bzoj1798维护序列seq

    一.题目 描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列 ...

  3. bzoj 维护序列seq(双标记线段树)

    Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 4184  Solved: 1518[Submit][Status][Discus ...

  4. BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )

    线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...

  5. 1798: [Ahoi2009]Seq 维护序列seq

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 2930  Solved: 1087[Submit ...

  6. bzoj 1798: [Ahoi2009]Seq 维护序列seq (线段树 ,多重标记下放)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 7773  Solved: 2792[Submit ...

  7. bzoj 1798: [Ahoi2009]Seq 维护序列seq 线段树 区间乘法区间加法 区间求和

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeO ...

  8. BZOJ1798 维护序列seq

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 8058  Solved: 2964[Submit ...

  9. Bzoj 1798: [Ahoi2009]Seq 维护序列seq(线段树区间操作)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小可 ...

随机推荐

  1. ReentrantReadWriteLock的使用

    ReentrantReadWriteLock的规则是: 多线程情况下:读-写互斥.写-读互斥.写-写互斥.读-读共享 验证“读-写互斥.写-读互斥.写-写互斥.读-读共享” //单个线程 读-读 不互 ...

  2. 题解 P4613 【[COCI2017-2018#5] Olivander】

    话说这道题,作为一个哈迷,是不能错过的 我很惊讶本蒟蒻竟然看得懂题面 好了,闲话少说,这道题,虽说是入门难度,但凭着良心说,它还是一道普及 - 的吧 看到标签,“高性能”,大脑的第一反应是快读. 是不 ...

  3. 四面体ply格式文件图和数据对应关系分析

    通过一个简单的文件来理解ply格式的文件是有所帮助的,我在网上找了一个四面体的ply文件,我通过meshlab打开看到的效果如下所示,我录制成gif文件,希望可以从不同角度展示出来: 同时我截图少许, ...

  4. Struts2 In Action笔记_页面到动作的数据流入和流出

    因为回答百度知道的一个问题,仔细查看了<Struts2 In Action>,深入细致的看了 “数据转移OGNL 和 构建视图-标签”,很多东西才恍然大悟. 一直觉得国外写的书很浮,不具有 ...

  5. komodo-edit

    sudo add-apt-repository ppa:mystic-mirage/komodo-edit sudo apt-get update sudo apt-get install komod ...

  6. HDU 2045 LELE的RPG难题

    递推 枚举起点状态 #include <algorithm> #include <iostream> #include <cstring> #include < ...

  7. SAP增强Enhancement

    第一代:基于源码增强(子过程subroutine) 第一代增强基于源代码,是SAP提供的一个空代码的子过程.在这个子过程中用户可以添加自己的代码,控制自己的需求.这类增强集中在一些文件名倒数第二个字符 ...

  8. 揭密 Vue 的双向绑定

    Vue 中需要输入什么内容的时候,自然会想到使用 <input v-model="xxx" /> 的方式来实现双向绑定.下面是一个最简单的示例 剖析Vue原理& ...

  9. JZOJ 5818. 【NOIP提高A组模拟2018.8.15】 做运动

    5818. [NOIP提高A组模拟2018.8.15] 做运动 (File IO): input:running.in output:running.out Time Limits: 2000 ms  ...

  10. 第7章 数据库访问与ORM 慕课网微信小程序开发学习笔记

    第7章 数据库访问与ORM https://coding.imooc.com/learn/list/97.html 目录: 7-1 数据库操作三种方式之原生SQL 19:09 7-2 从一个错误了解E ...