cf 1179 C
A
模拟出A不是最大值的情况,存起来。
最多有n个。当A为最大值的时候,后面n-1个数开始循环。
查询分两种情况讨论就行了
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int _=2e5+7;
ll read() {
ll x=0,f=1;char s=getchar();
for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
int n,m,gs;
pair<int,int> ans[_];
vector<int> a;
deque<int> q;
int main() {
n=read(),m=read();
int ma=0;
for(int i=1,x;i<=n;++i) {
x=read();
q.push_back(x);
ma=max(ma,x);
}
for(int i=1;i<=n;++i) {
int A=q.front();q.pop_front();
int B=q.front();q.pop_front();
ans[++gs]=make_pair(A,B);
//cout<<ans[gs].first<<" "<<ans[gs].second<<"<\n";
q.push_front(max(A,B));
q.push_back(min(A,B));
if(q.front()==ma) break;
}
q.pop_front();
while(!q.empty()) a.push_back(q.front()),q.pop_front();
//for(auto v:a) cout<<v<<"< ";cout<<"\n";
while(m --> 0) {
ll Query=read();
if(Query<=(ll)gs) printf("%d %d\n",ans[Query].first,ans[Query].second);
else printf("%d %d\n",ma,a[(Query-gs-1)%a.size()]);
}
return 0;
}
B
构造。
一行的很容易构造,\(1,m,2,m-2,3…………\)
两行也很容易,(1,1),(2,m),(1,2),(2,m-1)…………。
扩展的也很容易就是差不多一行的二维形式。
代码
#include <bits/stdc++.h>
using namespace std;
int n,m;
int main() {
scanf("%d%d",&m,&n);
int p=1,q=m;
pair<int,int> a=make_pair(1,1);
while(p<=q) {
int js=1,len=(p==q?n:2*n);
for(int i=1;i<=len;++i) {
printf("%d %d\n",a.first,a.second);
if(i!=len) a=make_pair(a.first==p?q:p,i&1?n-a.second+1:++js);
}
p++;q--;
a=(a.first>m/2)?make_pair(p,1):make_pair(q,1);
}
return 0;
}
C
转化一下,首先我们先排序a,没有影响。c为i选的菜的价格
那考虑一下b,i<j,c[i]<c[j],那么我们交换一下c[i],c[j]对最后我们拿到的菜没有影响。c[i]>c[j]就不管咯,最后b也是有序的了。
判断时候排序a,b,一对对的比较,第一个买不起的就是ans。可以想这份菜不一定他能买到,但最后一个“我”的一定买不到。但找到的第一份买不到的菜是一定剩下的,前面卖的更得起贵的菜(也买得到),后面买不起这份菜.a[i]至少要有i个人大于等于他。
用权值线段树求出权值最大的(能买得起的人数-rk<0)的值。
//第一个能买得起的人数-rk< 0的值
#include <bits/stdc++.h>
#define ls rt<<1
#define rs rt<<1|1
using namespace std;
const int _=1e6+7,N=1e6,INF=0x3f3f3f3f;
int n,m,q,a[_],b[_],tong[_];
struct node {
int l,r,mi,lazy;
}t[_<<2];
void pushup(int rt) {
t[rt].mi=min(t[ls].mi,t[rs].mi);
}
void pushdown(int rt) {
if(t[rt].lazy) {
t[ls].lazy+=t[rt].lazy,t[ls].mi+=t[rt].lazy;
t[rs].lazy+=t[rt].lazy,t[rs].mi+=t[rt].lazy;
t[rt].lazy=0;
}
}
void build(int l,int r,int rt) {
t[rt].l=l,t[rt].r=r,t[rt].mi=INF;
if(l==r) return;
int mid=(l+r)>>1;
build(l,mid,ls);
build(mid+1,r,rs);
}
void modify(int rt,int L,int R,int ad) {
if(L>R) return;
if(L<=t[rt].l&&t[rt].r<=R) {
t[rt].lazy+=ad,t[rt].mi+=ad;
return;
}
pushdown(rt);
int mid=(t[rt].l+t[rt].r)>>1;
if(L<=mid) modify(ls,L,R,ad);
if(R>mid) modify(rs,L,R,ad);
pushup(rt);
}
int query(int rt){
if(t[rt].l==t[rt].r) return t[rt].l;
pushdown(rt);
if(t[rs].mi<0) return query(rs);
else return query(ls);
}
int main() {
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i) scanf("%d",&a[i]);
for(int i=1;i<=m;++i) scanf("%d",&b[i]);
build(1,N,1);
for(int i=1;i<=n;++i) {
if(!tong[a[i]]) modify(1,a[i],a[i],-INF);
tong[a[i]]++;
modify(1,1,a[i],-1);
}
for(int i=1;i<=m;++i) modify(1,1,b[i],1);
scanf("%d",&q);
while(q --> 0) {
int opt,id,val;
scanf("%d%d%d",&opt,&id,&val);
if(opt==1) {
tong[a[id]]--;
if(!tong[a[id]]) modify(1,a[id],a[id],INF);
modify(1,1,a[id],1);
a[id]=val;
modify(1,1,a[id],-1);
if(!tong[a[id]]) modify(1,a[id],a[id],-INF);
tong[a[id]]++;
} else {
modify(1,1,b[id],-1);
b[id]=val;
modify(1,1,b[id],1);
}
if(t[1].mi>=0) puts("-1");
else printf("%d\n",query(1));
}
return 0;
}
cf 1179 C的更多相关文章
- ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'
凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- cf Round 613
A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...
- ARC下OC对象和CF对象之间的桥接(bridge)
在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...
- [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现
1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...
- CF memsql Start[c]UP 2.0 A
CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...
- CF memsql Start[c]UP 2.0 B
CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...
- CF #376 (Div. 2) C. dfs
1.CF #376 (Div. 2) C. Socks dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...
- CF #375 (Div. 2) D. bfs
1.CF #375 (Div. 2) D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...
随机推荐
- pacman 命令详解
Pacman 是一个命令行工具,这意味着当你执行下面的命令时,必须在终端或控制台中进行. 1.更新系统 在 Arch Linux 中,使用一条命令即可对整个系统进行更新:pacman -Syu 如果你 ...
- Java之路---Day19(set接口)
set接口 java.util.Set 接口和 java.util.List 接口一样,同样继承自 Collection 接口,它与 Collection 接口中的方 法基本一致,但是set接口中元素 ...
- 设计模式之(六)原型模式(ProtoType)
认识原型模式 原型模式是比较简单的设计模式.废话不多说,直接看定义:用原型实例指定创建对象的种类,并通过拷贝这些原型创建新的对象.通过实例指定种类,种类就是初始化的类,然后通过拷贝创建对象.先展示一个 ...
- 【转载】 Windows系统电脑通过设备管理器查看电脑配置信息
在采购电脑或者使用电脑的过程中,有时候我们需要查看到电脑的所有设备硬件信息,此时就可以通过Windows系统自带的设备管理器界面来查看该电脑所有的设备配置信息,包括CPU型号频率.内存.硬盘型号以及容 ...
- JavaScript 之 RegExp 对象
RegExp 正则表达式对象 一.正则表达式 正则表达式:定义字符串的组成规则. 1.单个字符:[ ] 如:[a].[ab].[a-zA-Z0-9] 特殊符号代表特殊含义的单个字符: \d:单个数字字 ...
- [转]C++类成员修饰const和mutable
const:常量,不变的 mutable:易变的 从意思上理解,可见const和mutable是一对反义词,它们都是C++的关键字. const成员函数不能修改调用它的对象.类的成员函数可以被声明为c ...
- 推荐一些github上的免费好书
本文转载自公众号:跟着小一写bug. 熬夜等于慢性自杀,那熬夜和喜欢的人说话,算不算是慢性殉情? 晚上好 小一来啦 有木有想哀家 其实今晚小一有个拳击课 可是 由于项目明天要演示 调一 ...
- MySQL Table--独立表空间
数据库表空间 独立表空间 在MySQL 5.6 中引入独立表空间的概念,启用独立表空间后,每个表将生成独立的文件来进行存储. 创建表时可以指定表存放的文件路径 ##首选需要确保innodb_file_ ...
- Java变量常量声明和定义
一.常量和变量 1.常量变量定义 在程序中存在大量的数据来代表程序的状态,其中有些数据在程序的运行过程中值会发生改变,有些数据在程序运行过程中值不能发生改变,这些数据在程序中分别被叫做变量和常量. 2 ...
- Win10 系统删除文件时提示文件不存在
Win10系统使用一段时间后用户都会定期进行删除清理系统垃圾,减少系统盘的容量占用,但在删除的过程中许多用户都遇到无法删除的情况,这一次系统提示"文件不存在",这该怎么解决?我们可 ...