CF#305-B. Mike and Fun-暴力模拟水题

来源:互联网 发布:2017年新出的网络剧 编辑:程序博客网 时间:2024/04/30 13:35

http://codeforces.com/contest/548/problem/B

题意:

给出n*m的01矩阵,给一个q,表示q次操作

操作 给出【i,j】,表示对 矩阵的i行k列的元素取反

每次操作后 给出 n行中, 最连续1的个数。


用一个ans【n】数组维护每一行的最多连续的1就好

n只有500,每次取反操作后,直接遍历把当前行更新后的最多连续的1记录到ans[i]

然后for(i=1:n)  遍历取一个最大的ans[i] 

复杂度  q*o(n)


#include <cstdio>#include <cmath>#include <cstring>#include <string>#include <algorithm>#include <iostream>#include <queue>#include <map>#include <set>#include <vector>using namespace std;int tm[505][505];int ans[505];       //i-th row's max continous 1int main(){        int n,m,q;    int i,j;    scanf("%d%d%d",&n,&m,&q);    for (i=1;i<=n;i++)    {        for (j=1;j<=m;j++)        {            scanf("%d",&tm[i][j]);        }    }    int tmp,maxx;    for (i=1;i<=n;i++)      //pre_    {         tmp=0;        maxx=0;        for (j=1;j<=m;j++)        {            if (tmp>maxx)                maxx=tmp;            if (j==1)                tmp=tm[i][j];            else                if (tm[i][j]==1)                {                                        if (tm[i][j-1]==1)                        tmp++;                    else                        tmp=1;                }                else                    tmp=0;                        }            if (tmp>maxx)                maxx=tmp;        ans[i]=maxx;    }    int a,b;    for (i=1;i<=q;i++)    {        scanf("%d%d",&a,&b);        tm[a][b]=!tm[a][b];        ///*************update         tmp=0;        maxx=0;                 for (j=1;j<=m;j++)        {            if (tmp>maxx)                maxx=tmp;            if (j==1)                tmp=tm[a][j];            else                if (tm[a][j]==1)                {                                        if (tm[a][j-1]==1)                        tmp++;                    else                        tmp=1;                }                else                    tmp=0;                        }            if (tmp>maxx)                maxx=tmp;        ans[a]=maxx;        maxx=0;        for (j=1;j<=n;j++)        {            if (ans[j]>maxx)                maxx=ans[j];        }        printf("%d\n",maxx);        //****************    } return 0;}


0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 孕38周贫血严重怎么办 孕38周有点贫血怎么办 脚被热水烫红了怎么办 学员练车撞死人怎么办 三胎意外来了该怎么办 因为飞机延误耽误行程怎么办 伤了朋友的心怎么办 羊蹄被绳子缠肿了怎么办 新老师教的不好怎么办 跟老公三观不合怎么办 突然有社保补扣怎么办 街头篮球篮板反应慢怎么办 换水了龙鱼顶缸怎么办 压着眼睛睡觉醒来模糊怎么办 天热眼睛有眼屎怎么办 眼睛里膜起来了怎么办 眼睛一边大一边小怎么办 眼白膜鼓起来了怎么办 主持问答环节没人提问怎么办 转学原学校不给怎么办 村长借东西不还怎么办 村长不上报建房申请怎么办 村长不上报建房手续申请怎么办 村长不给村民盖章怎么办? 找村干部办事难怎么办 洪洞县村长不给我盖章怎么办 睾丸穿刺取精只配到6个胚胎怎么办 孩子一只耳朵听不到声音怎么办 孕早期孕囊生长慢怎么办 试管2次不着床怎么办? pescm球员年龄大了怎么办 实况足球俱乐部经理球员老了怎么办 你不是我的菜怎么办 苹果平板电脑耳机有回音怎么办 obs直播有电流音怎么办 语音里网吧很吵怎么办 电脑k歌有延迟怎么办 想开个跆拳道馆怎么办营业执照? 壶嘴拐弯处漏水怎么办 裂纹茶壶嘴坏了怎么办 小孩刚上学怕她上火怎么办