code#5 P2 棋子
棋子
时间限制: 1.0 秒
空间限制: 512 MB
相关文件: 题目目录
题目描述
棋盘从左到右被分割成 n(n≤1000) 个格子,从左到右编号为1,2,...,n。棋盘上有 m(m≤n) 个棋子,编号为 1,2,...,m ,编号为i的棋子刚开始摆放在编号为 pi 的格子上,一个格子最多摆放一个棋子。每次操作小R可以选择一个棋子,将它移动到它右边第一个空着的格子中,如果它右边没有空着的格子了,那么这就是一个非法操作,执行一次非法操作不会对棋盘有任何改变。小R依次做了k次操作,如果一次操作是合法的,你需要输出这颗棋子移动到的格子的编号,如果是非法的,你需要输出"error!"。
输入格式
从标准输入读入数据。
第一行三个整数 n、m、k ,表示格子数、棋子数和操作数。
第二行 m 个正整数,第 i 个正整数表示 pi ,即第 i 个棋子的初始位置。
第三行 k 个正整数,第 i 个正整数表示 xi ,即第 i 次操作选定的棋子的编号。
输出格式
输出到标准输出。
输出 k 行,第i行表示第i次操作的结果。对于合法操作,输出棋子移动到的位置,对于非法操作,输出一行"error!"。
思路:
1000x10000暴力都能做,然而我看成了10000x10000
写了个超级麻烦的线段树
线段树怎么做呢?
首先,开一颗线段树
每个节点维护他的子树里面的0的个数
我们同时开一个映射数组
ys[i]表示当前编号为i的数在ys[i]这个位置
然后查询ys[i]~n这些位置的第一个0的位置
输出即可
如果一个没有
那就是不合法
合法的话更新线段树和映射数组即可
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<bitset>
#include<queue>
#include<cstdlib>
#include<algorithm>
#define rs 1024
#define rii register int i
#define rij register int j
using namespace std;
struct tree{
int cnt,val,wz;
}x[];
int n,m,k,ys[];
void mem(int l,int r,int bh)
{
x[bh].cnt=(r-l+);
if(l==r)
{
x[bh].wz=l;
return;
}
int mid=(l+r)/;
mem(l,mid,bh*);
mem(mid+,r,bh*+);
}
void add(int wz,int nl,int nr,int val,int bh)
{
if(nl==wz&&nr==wz)
{
if(val==)
{
x[bh].cnt=;
}
else
{
x[bh].cnt=;
}
return;
}
int mid=(nl+nr)/;
if(wz<=mid)
{
add(wz,nl,mid,val,bh*);
}
else
{
add(wz,mid+,nr,val,bh*+);
}
x[bh].cnt=x[bh*].cnt+x[bh*+].cnt;
}
int query(int l,int r,int nl,int nr,int bh)
{
if(l<nl)
{
l=nl;
}
if(r>nr)
{
r=nr;
}
if(l==nl&&nr==nl)
{
return x[bh].wz;
}
int re=;
int mid=(nl+nr)/;
if(l<=mid)
{
if(x[bh*].cnt!=)
{
re=query(l,r,nl,mid,bh*);
}
}
if(r>mid&&re==)
{
if(x[bh*+].cnt!=)
{
re=query(l,r,mid+,nr,bh*+);
}
}
return re;
}
int main()
{
// freopen("1.in","r",stdin);
scanf("%d%d%d",&n,&m,&k);
mem(,rs,);
for(rii=;i<=m;i++)
{
int val;
scanf("%d",&val);
ys[i]=val;
add(val,,rs,i,);
}
for(rii=;i<=k;i++)
{
int bh;
scanf("%d",&bh);
int wz=ys[bh];
if(wz+>n)
{
puts("error!");
continue;
}
int ltt=query(wz+,n,,rs,);
if(ltt==)
{
puts("error!");
continue;
}
else
{
printf("%d\n",ltt);
}
add(ltt,,rs,bh,);
add(wz,,rs,,);
ys[bh]=ltt;
}
}
code#5 P2 棋子的更多相关文章
- 2021.5.23 noip模拟2(排序|划艇|放棋子)
今天比昨天更惨,惨炸了 看到T1不会,跳!!! T2不会,再跳!!!! T3不会,后面没题了:::: 无奈无奈,重新看T1,然鹅时间已经过去了一个小时 然而我一想不出题来就抱着水瓶子喝水,然后跑厕所, ...
- [Exception JavaWeb 1] - Cause: com.microsoft.sqlserver.jdbc.SQLServerException: '@P2' 附近有语法错误。
严重: Servlet.service() for servlet [springMVC] in context with path [/ExceptionManageSystem] threw ex ...
- C# Distinct方法的使用笔记
引自:http://blog.csdn.net/shaopengfei/article/details/36426763 从C# 3.0开始提供了Distinct方法,这对于集合的使用有了更为丰富的方 ...
- JS-Promise笔记
转自:http://www.runoob.com/w3cnote/javascript-promise-object.html ECMAscript 6 原生提供了 Promise 对象. Promi ...
- [LeetCode] 196. Delete Duplicate Emails_Easy tag: SQL
Write a SQL query to delete all duplicate email entries in a table named Person, keeping only unique ...
- Python 類和對象 Class vs Object
類別定義 class 類別名: 例如: >>> class Point:... x = 0.0... y = 0.0 1. 宣告 >>> p1 = ...
- HackerRank Week of Code 26
好像这次week of code不是很难= = A int main(){ int n; int m; cin >> n >> m; cout<<(n+)/*)/) ...
- 【BZOJ-2668】交换棋子 最小费用最大流
2668: [cqoi2012]交换棋子 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 1055 Solved: 388[Submit][Status ...
- some code of c
// // main.c // LineList // // Created by Rubert on 16/9/11. // Copyright © 2016年 Study. All rights ...
随机推荐
- SPARK - Execute Framework
Spark函数详解系列之RDD基本转换 https://www.cnblogs.com/MOBIN/p/5373256.html The RDD provides low level API for ...
- 本地调试接口返回信息不对 以及 jar冲突问题
今天下午在本地调试的时候碰到个很奇怪的问题:服务调用接口,返回的明明是有数据的,然后通过gson转换对象后,对象里面并没有自己想要的数据.看了代码什么的都没有问题.思考到底是哪里出了问题,想了半天想到 ...
- Java web相关内容
我们即将学习Java web 这是通过查阅资料找到的和Java web 相关的内容. 一:Java web的含义 JavaWeb,是用Java技术来解决相关web互联网领域的技术总和.web包括:we ...
- C#.NET初识
1..NET平台特点 1)支持多种编程语言(C#.VB.F#.JavaScript.C++/CLI)-托管语言,此外还有Smaltalk.Ruby.Python.COBOL和Pascal的.NET编译 ...
- 有关从经典部署模型迁移到 Azure Resource Manager 部署模型的常见问题
此迁移计划是否影响 Azure 虚拟机上运行的任何现有服务或应用程序? 不可以. VM(经典)是公开上市的完全受支持的服务. 你可以继续使用这些资源来拓展你在 Azure 上的足迹. 如果我近期不打算 ...
- MSDN版、OEM版、RTM版、VOL版等的区别
我们常常听说操作系统的MSDN版.OEM版.RTM版.VOL版等等,它们到底是什么意思,有什么不同呢? (一)MSDN (Microsoft Developer Network)版MSDN软件是微软公 ...
- 浅析Linux操作系统是如何工作的(思维导图)
SA***189 多任务计算机运转机制如下思维导图所示: 小结: Linux操作系统是一个在时钟的节拍下,各个模块紧密协作.密不可分的整体,而整个Linux系统都是建立在存储程序的基础之上,正是有了程 ...
- Linux kill/pkill/killall命令详解
kill kill(terminate a process)命令用来终止指定的进程, 对于一个后台进程就须用kill命令来终止,我们就需要先使用ps/pidof/pstree/top等工具获取进程PI ...
- ASP.NET Core 上传多文件 超简单教程
示例源码下载地址 https://qcloud.coding.net/api/project/3915794/files/4463836/download 项目地址 https://dev.tence ...
- Python类的继承(进阶5)
转载请标明出处: http://www.cnblogs.com/why168888/p/6411918.html 本文出自:[Edwin博客园] Python类的继承(进阶5) 1. python中什 ...