蓝桥杯 历届真题 双向排序【第十二届】【省赛】【C组】

资源限制

内存限制:256.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s

改了半天只有60分,还是超时,还不知道怎么写,后面再看吧┭┮﹏┭┮

cpp 复制代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N = 1e6+10;
int n,m,t,d;
int a[N],b[N];
string s; 
signed main(){
	cin>>n>>m;
	for(int i=0;i<n;i++){
		a[i]=i+1;
	}
	int p,q,last_0=0,last_1=n;
	int flag=-1;
	for(int i=0;i<m;i++){
		cin>>p>>q;
		if(i==0){
			if(p==0){
				last_0=q;
				flag=0;
			}
			else{
				last_1=q;
				flag=1;
			}
		}else{
			if(p==0){
				if(flag==1){
					sort(a+last_1-1,a+n);
					last_1=n;	
				}
				last_0=max(last_0,q);
				flag=0;
				
			}else{
				if(flag==0){
					sort(a,a+last_0,greater<int>());
					last_0=0;	
				}
				last_1=min(last_1,q);
				flag=1;	
			}
		}
	}
	if(flag==0){
		sort(a,a+last_0,greater<int>());
	}else{
		sort(a+last_1-1,a+n);
	}
	
	for(int i=0;i<n;i++){
		cout<<a[i]<<" ";
	}
	
	return 0;
}

看别人代码发现自己只考虑了两种情况:

一、输入为连续的0,那么最大的q生效,作为排序右边界;

二、输入为连续的1,那么最小的q生效,作为排序左边界;

还应该有:

  • 交替输入且第一次输入0,第二次1,第三次0,且第三次q比第一次大,那么前两次作废;
  • 交替输入且第一次输入1,第二次0,第三次1,且第三次q比第一次小,那么前两次作废;
相关推荐
@卞1 小时前
从零实现一个高并发内存池(1)--- 项目介绍
c++
wjlnew1 小时前
c++中的内存管理:栈,堆及RALL机制
c++
denggun123451 小时前
悬垂指针 和 野指针
数据结构
Pluto_CSND2 小时前
JSONPath解析JSON数据结构
java·数据结构·json
无限进步_2 小时前
【C语言】用队列实现栈:数据结构转换的巧妙设计
c语言·开发语言·数据结构·c++·链表·visual studio
Xの哲學2 小时前
从硬中断到 softirq:Linux 软中断机制的全景解剖
linux·服务器·网络·算法·边缘计算
liu****2 小时前
02_Pandas_数据结构
数据结构·python·pandas·python基础
生信碱移2 小时前
单细胞空转CNV分析工具:比 inferCNV 快10倍?!兼容单细胞与空转的 CNV 分析与聚类,竟然还支持肿瘤的亚克隆树构建!
算法·机器学习·数据挖掘·数据分析·聚类
Brduino脑机接口技术答疑2 小时前
TDCA 算法在 SSVEP 场景中:Padding 的应用对象与工程实践指南
人工智能·python·算法·数据分析·脑机接口·eeg
optimistic_chen2 小时前
【Redis 系列】常用数据结构---Hash类型
linux·数据结构·redis·分布式·哈希算法