(今天yy出奇的不活泼,认真的吓人)

【传送门】

算法标签:


思路啊qwq:

  • part1:

  • 想法是先暴搜出每一行的1,取最前方一个1和最后方一个1,然后中间的0填上色,80分,因为没有考虑到“00011100101”这样类似的的情况。
  • #include<iostream>
    #include<cstring>
    #include<algorithm>
    #include<cstdio>
    #include<queue>
    #include<cmath>
    using namespace std;
    int n,minx=,miny[],maxx,maxy[];
    int a[][],ans[][];
    bool vis[][];
    int dx[]={,,-,};
    int dy[]={,,,-};
    struct az{
    int x,y;
    };
    az fz(int x,int y){
    az rtn;
    rtn.x=x;
    rtn.y=y;
    return rtn;
    }
    bool pan(int x,int y){
    return x>=&&y>=&&x<=n&&y<=n&&vis[x][y]==;
    }
    queue<az> q;
    void bfs(){
    q.push(fz(,));
    vis[][]=;
    int num=;
    while(!q.empty()){
    az h=q.front();
    q.pop();
    for(int i=;i<;i++){
    int xx=h.x,yy=h.y;
    if(pan(xx+dx[i],yy+dy[i])){
    xx+=dx[i];
    yy+=dy[i];
    if(a[xx][yy]==){
    ans[++num][]=xx;
    ans[num][]=yy;
    if(xx<minx)minx=xx;if(xx>maxx)maxx=xx;
    if(yy>maxy[xx])maxy[xx]=yy;
    if(yy<miny[xx])miny[xx]=yy;
    }
    q.push(fz(xx,yy));
    vis[xx][yy]=;
    }
    }
    }
    for(int i=minx;i<=maxx;i++)
    for(int j=miny[i];j<=maxy[i];j++)
    if(a[i][j]==)
    a[i][j]=;
    }
    int main(){
    scanf("%d",&n);
    for(int i=;i<=n;i++)
    for(int j=;j<=n;j++)
    scanf("%d",&a[i][j]);
    memset(miny,,sizeof(miny));
    bfs();
    for(int i=;i<=n;i++){
    for(int j=;j<=n;j++)
    cout<<a[i][j]<<" ";
    cout<<endl;
    }
    }

    然后下载了最后一个数据,我做了一个伟大的打表水数据的决定qwq:

  • 但是良心不安啊,于是我又想了一个神奇的思路:
  • 根据题意,当找到第一个1时,其右下必然是圈内的0,那么只要从这个0开始广搜寻找联通块就可以了。
  • 所以就这这个写了一个程序:
  • #include<iostream>
    #include<cstring>
    #include<algorithm>
    #include<cstdio>
    #include<queue>
    #include<cmath>
    using namespace std;
    int n,sy,sx;
    int a[][];
    bool vis[][],b;
    int dx[]={,,-,};
    int dy[]={,,,-};
    bool panduan(int x,int y){ }
    struct az{
    int x,y;
    };
    az fz(int x,int y){
    az rtn;
    rtn.x=x;
    rtn.y=y;
    return rtn;
    }
    bool pan(int x,int y){
    return x>=&&y>=&&x<=n&&y<=n&&vis[x][y]==;
    }
    queue<az> q;
    void bfs(){
    q.push(fz(,));
    vis[][]=;
    int num=;
    while(!q.empty()){
    az h=q.front();
    q.pop();
    for(int i=;i<;i++){
    int xx=h.x,yy=h.y;
    if(a[xx][yy]==){
    sx=xx+;
    sy=yy+;
    b=;
    break;
    }
    if(pan(xx+dx[i],yy+dy[i])){
    xx+=dx[i];
    yy+=dy[i];
    q.push(fz(xx,yy));
    vis[xx][yy]=;
    }
    }
    if(b==)break;
    }
    queue<az> Q;
    Q.push(fz(sx,sy));
    a[sx][sy]=;
    while(!Q.empty()){
    az hh=Q.front();
    Q.pop();
    for(int i=;i<;i++){
    int aa=hh.x,bb=hh.y;
    aa+=dx[i];
    bb+=dy[i];
    if(a[aa][bb]==){
    Q.push(fz(aa,bb));
    a[aa][bb]=;
    } }
    }
    }
    int main(){
    scanf("%d",&n);
    for(int i=;i<=n;i++)
    for(int j=;j<=n;j++)
    scanf("%d",&a[i][j]);
    bfs();
    for(int i=;i<=n;i++){
    for(int j=;j<=n;j++)
    cout<<a[i][j]<<" ";
    cout<<endl;
    }
    }

    end-

【洛谷p1162】填涂颜色的更多相关文章

  1. 洛谷 P1162 填涂颜色 DFS

    P1162 填涂颜色 https://www.luogu.com.cn/problem/P1162 qaq搜索好抽象啊,蒟蒻表示难以理解,搞半天才做出来一道题,很挫败www 思路 染色法.找墙壁外的连 ...

  2. 洛谷P1162—填涂颜色

    这应该是是第一次记录洛谷题库里的题目吧: 题目描述 由数字00组成的方阵中,有一任意形状闭合圈,闭合圈由数字11构成,围圈时只走上下左右44个方向.现要求把闭合圈内的所有空间都填写成22.例如:6 \ ...

  3. 洛谷 P1162 填涂颜色

    题目链接:https://www.luogu.org/problemnew/show/P1162 题目描述由数字0组成的方阵中,有一任意形状闭合圈,闭合圈由数字1构成,围圈时只走上下左右4个方向.现要 ...

  4. 洛谷 P1162 填涂颜色【DFS】

    题目链接:https://www.luogu.org/problemnew/show/P1162 题目描述 由数字 0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字 1 构成,围圈时只走上下左右 4 ...

  5. 洛谷—— P1162 填涂颜色

    https://www.luogu.org/problem/show?pid=1162 题目描述 由数字0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字1构成,围圈时只走上下左右4个方向.现要求把闭 ...

  6. 洛谷 P1162 填涂颜色题解

    题目描述 由数字00组成的方阵中,有一任意形状闭合圈,闭合圈由数字11构成,围圈时只走上下左右44个方向.现要求把闭合圈内的所有空间都填写成22.例如:6 \times 66×6的方阵(n=6n=6) ...

  7. 洛谷P1162 填涂颜色【bfs】

    题目链接:https://www.luogu.org/problemnew/show/P1162 题意: 有一个0和1组成的矩阵,一些1组成一个闭合圈,圈住一些0,现在要把被圈住的这些0变成2输出. ...

  8. 洛谷P1162 填涂颜色

    题目链接:https://www.luogu.org/problemnew/show/P1162 这道题是LITTLESUN写的第一道BFS哦! 对于这道题的的思路是把封闭图形外边的0标记一边,在最后 ...

  9. 洛谷 - P1162 - 填涂颜色 - 简单搜索

    https://www.luogu.org/problemnew/show/P1162 在外面加一圈0把0连起来,然后把所有0换成2,再从(0,0)把连通的2全部改回来. 这也是一个判断内外圈的好办法 ...

  10. luogu P1162 填涂颜色 x

    P1162 填涂颜色 题目描述 由数字0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字1构成,围圈时只走上下左右4个方向.现要求把闭合圈内的所有空间都填写成2.例如:6X6的方阵(n=6),涂色前和 ...

随机推荐

  1. 排序之冒泡排序(bubblesort)

    package com.pailian; /* * 冒泡排序 * 比较相邻的俩位数,这样每轮比较都会出现一个最大值或最小值 * 下一轮比较就会减少一次(因为已经知道了一个最大值或最小值) * 注意根据 ...

  2. php通过phpize安装扩展

    //下载libevent扩展文件压缩包(在当前系统哪个目录下载随意) ~# wget http://pecl.php.net/get/libevent-0.1.0.tgz //解压文件 ~# tar ...

  3. 比NGINX更快:nginx-1.15.5 vs mongols-1.2.3

    nginx是多进程web服务器的优秀代表. 本文要用mongols-1.2.3实现一个比nginx更快的多进程的web服务器. mongols是C++ 服务器基础设施库, 它的主要特性如下: tcp ...

  4. wpf treeview 数据绑定 递归绑定节点

    1.先上效果 将所有节点加入ComboBox数据源,在ComboBox中选择时下方Treeview显示该节点下的子节点. 1.xaml文件,将以下代码加入界面合适位置 <StackPanel&g ...

  5. 2018-2019-2 网络对抗技术 20165316 Exp5 MSF基础应用

    2018-2019-2 网络对抗技术 20165316 Exp5 MSF基础应用 目录 原理与实践说明 实践原理 实践内容概述 基础问题回答 攻击实例 主动攻击的实践 ms08_067_netapi: ...

  6. 使用Python的库qrcode生成二维码

    现在有很多二维码的生成工具,在线的,或者安装的软件,都可以进行生成二维码.今天我用Python的qrcode库生成二维码.需要预先安装  Image 库 安装 用pip安装 # pip install ...

  7. MTK(android init.rc) 写一个开机启动的服务

    在开机往往我们想要做一些初始化的操作,这时候可以使用init.rc文件来实现,当然书写一个开机启动的服务也需要规范的. 假设是C程序,则需要准备C程序的源码,在我的例程中是一个在开机完成(androi ...

  8. bloc控制读写文件

    import 'package:flutter/material.dart'; import 'dart:io'; import 'package:path_provider/path_provide ...

  9. 【题解】Luogu P4867 Gty的二逼妹子序列

    原题传送门 同Luogu P4396 [AHOI2013]作业 询问多了10倍,但还能跑过(smog #include <bits/stdc++.h> #define N 100005 # ...

  10. Axure无法签出,团队配合时无法导入项目

    SVN管理项目,团队多人合作维护 在Axure签出时,报错. 提示:无法创建目录 ... 设备上没有空间 SVN也检出失败 当然,还有其他情况 如:未将对象引用设置到对象的实例.等等 个别提示如下图: ...