目录

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的更多相关文章

  1. 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 ...

  2. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  3. cf Round 613

    A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...

  4. ARC下OC对象和CF对象之间的桥接(bridge)

    在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...

  5. [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现

    1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...

  6. 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 ...

  7. 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 ...

  8. CF #376 (Div. 2) C. dfs

    1.CF #376 (Div. 2)    C. Socks       dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...

  9. CF #375 (Div. 2) D. bfs

    1.CF #375 (Div. 2)  D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...

随机推荐

  1. Google Chrome 浏览器JS无法更新解决办法

    JS无法更新原因: 浏览器为了加载快,默认是按照自定规则更新缓存,非实时更新. 我们在开发的时候,JS变动很快,需要即时让浏览器加载最新文件,也就是禁用浏览器缓存 (1)使用F12进入开发者模式,找到 ...

  2. Spring Web MVC框架简介

    Web MVC framework框架 Spring Web MVC框架简介 Spring MVC的核心是`DispatcherServlet`,该类作用非常多,分发请求处理,配置处理器映射,处理视图 ...

  3. Apache Tomcat 9.0 Tomcat9 服务无法启动。发生服务特定错误: 4.

    在Tomcat的安装目录下,bin文件夹里面 找到tomcat9w.exe 双击进去,将第四页java里面第一个复选框Use default 选中 保存即可启动tomcat9服务

  4. docker系列之一:初见docker

    什么是docker? docker是目前linux最流行的容器技术,Docker 将应用程序与该程序的依赖,打包在一个文件里面.运行这个文件,就会生成一个虚拟容器.程序在这个虚拟容器里运行,就好像在真 ...

  5. JavaScript---Dom树详解,节点查找方式(直接(id,class,tag),间接(父子,兄弟)),节点操作(增删改查,赋值节点,替换节点,),节点属性操作(增删改查),节点文本的操作(增删改查),事件

    JavaScript---Dom树详解,节点查找方式(直接(id,class,tag),间接(父子,兄弟)),节点操作(增删改查,赋值节点,替换节点,),节点属性操作(增删改查),节点文本的操作(增删 ...

  6. 2019-08-02 原生ajax搜索

    <html> <meta charset="utf-8"/> <head><title>搜索页</title></ ...

  7. npm err! Unexpected end of JSON input while parsing near解决办法

    npm install时出现npm err! Unexpected end of JSON input while parsing near错误 输入  npm cache clean --fore ...

  8. CSRF漏洞的挖掘与利用

    0x01 CSRF的攻击原理 CSRF 百度上的意思是跨站请求伪造,其实最简单的理解我们可以这么讲,假如一个微博关注用户的一个功能,存在CSRF漏洞,那么此时黑客只需要伪造一个页面让受害者间接或者直接 ...

  9. 汽配生产的精益化管理如何实现?这家3000人的企业靠MES系统进行管理

    精益达电子事业部电子车间于在完成车间改造后,生产能力得到大幅提升.但生产制造过程信息化仍处于空白,众多设备处于单机工作模式,车间现场计划排产.物料管理.质量管理等,还处于原始的凭经验.人工干预方式. ...

  10. FFMPEG SDK 开发介绍(原创)

    来源:http://blog.sina.com.cn/s/blog_62a8419a01016exv.html 本文是作者在使用ffmpeg sdk开发过程中的实际经验,现在与大家分享,欢迎学习交流. ...