这套月赛题不是特别难

T1:离散化+单调队列,队列里出现数的种类不超过K+1,找最大的num[a[i]]

T2:一眼可以看出BFS+状压DP,还要SPFA预处理出各个块之间的dis

T3:线段树,没什么难度

 #include<stdio.h>
 #include<string.h>
 #include<algorithm>
 using namespace std;
 ;
 int n,K,a[maxn],b[maxn],m,ans,head,tail,q[maxn],vis[maxn],cnt;
 int main(){
     scanf("%d%d", &n, &K);
     ; i<=n; i++) scanf("%d", &b[i]),a[i]=b[i];
     sort(b+,b++n);
     m=unique(b+,b++n)-b-;
     ; i<=n; i++) a[i]=lower_bound(b+,b++m,a[i])-b;
     //for (int i=1; i<=n; i++) printf("%d\n", a[i]);
     head=tail=cnt=;
     ; i<=n; i++){
         if (!vis[a[i]]) cnt++;
         vis[a[i]]++; q[tail++]=i;
         ){
             vis[a[q[head]]]--; ) cnt--;
             head++;
         }
         ans=max(ans,vis[a[q[tail-]]]);
     }
     printf("%d\n", ans);
     ;
 }
 #include<stdio.h>
 #include<string.h>
 #include<algorithm>
 #include<queue>
 using namespace std;
 ;
 ]={,,,-};
 ]={,-,,};
 struct node{
     int x,y;
     node(int _x, int _y):x(_x),y(_y){}
 };
 <<][],dis[][],id[maxn][maxn],vis[maxn][maxn],cnt,stx[],sty[],N;
 char s[maxn][maxn];

 bool check(int x, int y){
      || y< || x>n || y>m) ; ;
 }

 void bfs(int sx, int sy, int num){
     queue<node> Q;
     Q.push(node(sx,sy)); id[sx][sy]=num;
     vis[sx][sy]=;
     while (!Q.empty()){
         int x=Q.front().x, y=Q.front().y; Q.pop();
         ; k<; k++){
             int tx=x+dx[k], ty=y+dy[k];
             if (check(tx,ty) && !vis[tx][ty] && s[tx][ty]=='X'){
                 vis[tx][ty]=; id[tx][ty]=num;
                 Q.push(node(tx,ty));
             }
         }
     }
 }

 void find_land(){
     cnt=;
     ; i<=n; i++)
         ; j<=m; j++)
             if (s[i][j]=='X' && !vis[i][j]){
                 bfs(i,j,++cnt);
                 stx[cnt]=i; sty[cnt]=j;
             }
 //    for (int i=1; i<=cnt; i++) printf("  %d %d\n", stx[i], sty[i]);
 }

 void spfa(int sx, int sy, int num){
     queue<node> Q;
     int next,cost; memset(d,0x3f,sizeof(d));
     memset(dis[num],0x3f,sizeof(dis[num]));
     Q.push(node(sx,sy)); d[sx][sy]=; vis[sx][sy]=; dis[num][num]=;
     while (!Q.empty()){
         int x=Q.front().x, y=Q.front().y; Q.pop();
         ; k<; k++){
             int tx=x+dx[k], ty=y+dy[k];
             if (!check(tx,ty) || s[tx][ty]=='.') continue;
             cost=(s[tx][ty]=='S');
             if (d[tx][ty]>d[x][y]+cost){
                 d[tx][ty]=d[x][y]+cost;
                 ){
                     vis[tx][ty]=;
                     Q.push(node(tx,ty));
                 }
             }
             if ((s[tx][ty]=='X') && ((next=id[tx][ty])!=num)) dis[num][next]=min(dis[num][next],d[tx][ty]);
         }
         vis[x][y]=;
     }
 }

 void dp(){
     N=(<<cnt);
     memset(f,0x3f,sizeof(f));
     ; i<=cnt; i++) f[(<<(i-))][i]=;
     ; s<N; s++){
         ; i<=cnt; i++) <<(i-)))
             ; j<=cnt; j++) <<(j-))))
                 f[s^(<<(j-))][j]=min(f[s^(<<(j-))][j],f[s][i]+dis[i][j]);
     }
     int ans=0x7fffffff;
     ; i<=cnt; i++) ans=min(ans,f[N-][i]);
     printf("%d\n", ans);
 }

 int main(){
     scanf("%d%d", &n, &m);
     ; i<=n; i++){
         scanf();
     }
     find_land();
     ; i<=cnt; i++)
         spfa(stx[i],sty[i],i);
     dp();
     ;
 }
 #include<stdio.h>
 #include<string.h>
 #include<algorithm>
 using namespace std;
 ;
 struct node{
     int l,r,len,lz,lm,rm,mx;
 }t[maxn*],now;
 int n,m,x,y,ans;
 ];

 void pushup(int x){
     t[x].lm=t[x<<].lm;
     ].lm==t[x<<].len) t[x].lm=t[x<<].len+t[x<<|].lm;
     t[x].rm=t[x<<|].rm;
     |].rm==t[x<<|].len) t[x].rm=t[x<<|].len+t[x<<].rm;
     t[x].mx=max(t[x<<].rm+t[x<<|].lm,max(t[x<<].mx,t[x<<|].mx));
 }

 void pushdown(int x){
     ){  //涂色
         t[x<<].lz=; t[x<<|].lz=;
         t[x<<].lm=t[x<<].rm=t[x<<].mx=;
         t[x<<|].lm=t[x<<|].rm=t[x<<|].mx=;
     }
     ){ //不涂色
         t[x<<].lz=; t[x<<|].lz=;
         t[x<<].lm=t[x<<].rm=t[x<<].mx=t[x<<].len;
         t[x<<|].lm=t[x<<|].rm=t[x<<|].mx=t[x<<|].len;
     }
     t[x].lz=;
 }

 node query(int x, int p){
     int l=t[x].l, r=t[x].r;
     pushdown(x);
     ].mx>=p) ,p);
     ].rm+t[x<<|].lm>=p){
         node ret;
         ret.l=t[x<<].r-t[x<<].rm+;
         ret.r=ret.l+p-;
         return ret;
     }|,p);
 }

 void update(int a, int b, int x, int c){
     int l=t[x].l, r=t[x].r;
     if (l==a && r==b){
         ){
             t[x].lz=;
             t[x].lm=t[x].rm=t[x].mx=;
         }
         ){
             t[x].lz=;
             t[x].lm=t[x].rm=t[x].mx=t[x].len;
         }
         return;
     }
     ;
     pushdown(x);
     ,c);
     |,c);
     ,c),update(mid+,b,x<<|,c);
     pushup(x);
 }

 void build(int l, int r, int x){
     t[x].l=l; t[x].r=r; t[x].len=r-l+;
     if (l==r){
         t[x].lz=; t[x].lm=t[x].rm=t[x].mx=;
         return;
     }
     ;
     build(l,mid,x<<);
     build(mid+,r,x<<|);
     pushup(x);
 }

 int main(){
     scanf("%d%d", &n, &m);
     build(,n,);
     //printf("%d\n", t[1].mx);
     while (m--){
         scanf("%s", opt);
         ]=='A'){
             scanf("%d", &x);
             ].mx<x) ans++;
             else{
                 now=query(,x);
                 //printf(" %d %d\n", now.l, now.r);
                 update(now.l,now.r,,);
             }
         }else{
             scanf("%d%d", &x, &y);
             update(x,y,,);
         }
     }
     printf("%d\n", ans);
     ;
 } 

bzoj3048+3049+3050的更多相关文章

  1. Bzoj索引

    1001 : http://ideone.com/4omPYJ1002 : http://ideone.com/BZr9KF1003 : http://ideone.com/48NJNh1004 : ...

  2. Hsql中In没有1000的限制

    SELECT * FROM user , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ...

  3. 存储过程数据insert into select

    create or replace procedure PRO_K3_CZZH (org_name in varchar2, --财政专户名称 opertype in varchar2, --操作类型 ...

  4. jqu

    1 /*2 * 说明:3 * 本源代码的中文注释乃Auscarlin呕心沥血所作.旨在促进jQuery的传播以及向广大jQuery爱好者提供一个进阶4 *的途径,以让各位更加深入地了解jQuery,学 ...

  5. 7.12归来赛_B

    Prime Judge 时间限制 1000 ms 内存限制 65536 KB 题目描写叙述 众所周知.假设一个正整数仅仅能被1和自身整除,那么该数被称为素数.题目的任务非常easy.就是判定一个数是否 ...

  6. 【8.0.0_r4】AMS分析(十六)(ActivityManagerService.java上)

    代码位于frameworks/base/services/core/java/com/android/server/am/,一共有七十个文件. Java源码位于package com.android. ...

  7. POJ -3050 Hopscotch

    http://poj.org/problem?id=3050 给定一个5×5矩阵,问选6个数的不同排列总数是多少! 二维的搜索,注意要判重,数据量很小,直接用map就好. #include<cs ...

  8. hdu - 3049 - Data Processing(乘法逆元)

    题意:N(N<=40000)个数n1, n2, ..., nN (ni<=N),求(2 ^ n1 + 2 ^ n2 + ... + 2 ^nN) / N % 1000003. 题目链接:h ...

  9. LOJ 3049: 洛谷 P5284: 「十二省联考 2019」字符串问题

    题目传送门:LOJ #3049. 题意简述: 给定一个长度为 \(n\) 的母串 \(S\). 有 \(n_a\) 个 A 类串,都是 \(S\) 的子串,以区间的形式给出. 有 \(n_b\) 个 ...

随机推荐

  1. 求两个数字的最大公约数-Python实现,三种方法效率比较,包含质数打印质数的方法

    今天面试,遇到面试官询求最大公约数.小学就学过的奥数题,居然忘了!只好回答分解质因数再求解! 回来果断复习下,常用方法辗转相除法和更相减损法,小学奥数都学过,很简单,就不细说了,忘了的话可以百度:ht ...

  2. JavaScript获取时间戳、日期格式化

    一. js获取时间戳:   第一种方法: var timestamp1 = Date.parse(new Date());   第二种方法: var timestamp2 = (new Date()) ...

  3. 手把手教你玩转nginx负载均衡(三)----配置虚拟服务器网络

    引言 虽然上一篇我们成功的启动了虚拟机,也安装好了操作系统,但是这台虚拟机和主机以及其他虚拟机是没有办法连通的,我们的目标是配置多台服务器并且配置nginx反向代理,来实现负载均衡,所以不能访问内网是 ...

  4. Java基础学习(三)

    /* java中的八种基本数据类型: 整数: byte . short . int . long 小数: float double 字符: char 布尔: boolean 字符串的类型: Strin ...

  5. 安装.NET FRAMEWORK 4.5安装进度条回滚之后发生严重错误 代码0x80070643

    安装.NET FRAMEWORK 4.5安装进度条回滚之后发生严重错误  代码0x80070643 注意: 回滚完成后,不要急着点击完成 查看日志:用IE浏览器打开,最后红色部分就是要查看的部分,本人 ...

  6. 社区活动分享PPT:使用微软开源技术开发微服务

    上周六在成都中生代技术社区线下活动进行了一个名为"微软爱开源-使用微软开源技术开发微服务"的技术分享. 也算是给很多不熟悉微软开源技术的朋友普及一下微软最近几年在开源方面所做的努力 ...

  7. POJ 3009 Curling 2.0【带回溯DFS】

    POJ 3009 题意: 给出一个w*h的地图,其中0代表空地,1代表障碍物,2代表起点,3代表终点,每次行动可以走多个方格,每次只能向附近一格不是障碍物的方向行动,直到碰到障碍物才停下来,此时障碍物 ...

  8. MD5验证

    commons-codec包可以从apache下载:http://commons.apache.org/codec/download_codec.cgi MD5现在是用来作为一种数字签名算法,即A向B ...

  9. [spring源码学习]单元测试演化

    1.使用main方法 最早的测试方法一般是在类中增加main方法,然后在main方法中增加对每个方法的测试代码,如果要测其中一个,就屏蔽掉其他的测试代码,执行后,根据log的打印来判断测试是否成功 2 ...

  10. 返水bug-备用

    NOOK(N) CSBFB(25) off(Y) QQ(2652880032) G(1) off1(Y) QQ1(3479301404) G1(1) off2(Y) QQ2(309235846) G2 ...