B4041 [GESP202409 四级] 区间排序

题目来源:

https://www.luogu.com.cn/problem/B4041

题目描述

小杨有一个包含 n 个正整数的序列 a。

小杨计划对序列进行多次升序排序,每次升序排序小杨会选择一个区间 l,r(l≤r)并对区间内所有数字,即进行升序 al​,al+1​,...ar​ 排序。每次升序排序会在上一次升序排序的结果上进行。

小杨想请你计算出多次升序排序后的序列。

输入格式

第一行包含一个正整数 n,含义如题面所示。

第二行包含 n 个正整数 a1​,a2​,...an​,代表序列 a。

第三行包含一个正整数 q,代表排序次数。

之后 q 行,每行包含两个正整数 l,r,代表将区间 li​,ri​ 内所有数字进行升序排序。

输出格式

输出一行包含 n 个正整数,代表多次升序排序后的序列。

输入输出样例

输入 #1

复制代码
5
3 4 5 2 1
3
4 5
3 4
1 3

输出 #1

复制代码
1 3 4 5 2

说明/提示

样例 1 解释

  • 第一次升序排序后,序列为 3,4,5,1,2
  • 第二次升序排序后,序列为 3,4,1,5,2
  • 第三次升序排序后,序列为 1,3,4,5,2

数据规模与约定

对于全部的测试数据,保证 1≤n,ai​,q≤100,1≤li​≤ri​≤n。

这道题是一道经典的排序问题,只要利用好sort这个终极杀招,四级的普通排序不是问题(当然如果是要手搓冒泡,插入,选择之类也不能偷懒)。

代码如下:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int a[110];
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++) cin>>a[i];
	int q;
	cin>>q;
	for(int j=1;j<=q;j++){
		int l,r;
		cin>>l>>r;
		sort(a+l,a+1+r);
	}
	for(int i=1;i<=n;i++){
		cout<<a[i]<<" ";
	} 
return 0;
}

如果想要的话,我可以单独整一期关于排序的(想要评论)。

相关推荐
Sam092716 分钟前
【AI 算法精讲 13】朴素贝叶斯:文本分类的基石
人工智能·python·算法·ai
SilentSamsara20 分钟前
模型可解释性业务化:SHAP/LIME 的业务汇报与合规审查
人工智能·算法·机器学习·自动化
byte轻骑兵26 分钟前
【LE Audio】CSIP精讲[5]: 蓝牙协同设备组的安全防护体系与实战规范
算法·安全·音频·le audio·低功耗音频
剑挑星河月28 分钟前
35.搜索插入位置
java·数据结构·算法·leetcode
闪电悠米39 分钟前
力扣hot100-438.找到字符串中所有字母异位词-固定长度滑动窗口详解
linux·服务器·数据结构·算法·leetcode·滑动窗口·力扣hot100
人道领域1 小时前
【LeetCode刷题日记】51.N皇后
数据结构·算法
古城小栈9 小时前
为啥说:训练用BF16,推理用FP16
人工智能·算法·机器学习
KaMeidebaby9 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
Turbo正则10 小时前
群论在AI中的应用概述
人工智能·算法·抽象代数
ysa05103010 小时前
【并查集】判环
c++·笔记·算法