二维数组八个方向的判断--牛客刷题1023-病菌感染

2024-03-09 05:10

本文主要是介绍二维数组八个方向的判断--牛客刷题1023-病菌感染,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

铁子和顺溜上生物课的时候不小心将几滴超级病菌滴到了培养皿上,这可急坏了他们。
培养皿可以被看成一个n*n的方格,最初病菌滴在了这n*n的格子中的某些格子,病菌的传染方式是这样的,如果一个方格与两个或多个被感染的方格相邻(两个方格相邻当且仅当它们只有一条公共边),那么它就会被感染。现在铁子和顺溜想知道,最终所有的方格会不会都被感染。

输入描述:

第一行两个整数n,m。n表示方格的规格,m表示最初病菌所在的格子数。(1 ≤ n ≤ 1000, 0 < m < n)。

接下来m行每行两个整数xi,yi表示第xi行的第yi个格子有病菌。

数据保证不会有两个病菌初始时在同一个格子。

输出描述:

如果最终所有的方格都会被感染,输出 YES。
否则输出 NO。

示例1

输入

3 2
1 2
2 2

输出

NO

我们先去分析题的大意

  • 一个n*n的方格  :明显是个矩阵----> 要用到二维数组了
  • ,如果一个方格与两个或多个被感染的方格相邻(两个方格相邻当且仅当它们只有一条公共边),那么它就会被感染。现在铁子和顺溜想知道,最终所有的方格会不会都被感染
  • 这个说明的是病毒是在四个方向上进行的,上 下 左 右:
  • 接下来m行每行两个整数xi,yi表示第xi行的第yi个格子有病菌。
  • 数据保证不会有两个病菌初始时在同一个格子。 --------->是说输入坐标

其实说到这里,大致是有自己的方向来判断了,就是在上下左右四个方向上来判断呗,为了便于理解,我按照题意打印出如下图形,0(病毒),那么我就开始去走起

 这个是便于理解,但是在做题的时候,为了方便,我直接把所有的元素变成了0,那么是病毒是则是1,然后我在遍历中走一圈的时候,可以来进行加法,当大于2时,就说明你的周围是最少有三个病毒,然后就被感染,然后在遍历走去

while (m > 0) {
        cin >> x >> y;
        arr[x][y] = 1;
        m--;
    } 

    for (i = 1; i <= n; i++)
    {
        for (j = 1; j <= n; j++)
        {    
            if (arr[i][j] != 1) { //上下左右四个方向的判断
                t = arr[i][j] + arr[i][j + 1] + arr[i][j - 1] + arr[i + 1][j] + arr[i - 1][j];
                if (t < 2){cout << "NO" << endl; return 0;} 
            }       

        }

    }
    cout<<"YES"<<endl;
return 0;

 全部的代码如下

#include <iostream>
#include <iomanip>
#define N 1001
using namespace std;
int main()
{int arr[N][N] = {0};int n, m, i, j, x, y,t, flag = 0;cin >> n >> m;while (m > 0) {cin >> x >> y;arr[x][y] = 1;m--;} for (i = 1; i <= n; i++){for (j = 1; j <= n; j++){if (arr[i][j] != 1) { //上下左右四个方向的判断t = arr[i][j] + arr[i][j + 1] + arr[i][j - 1] + arr[i + 1][j] + arr[i - 1][j];if (t < 2){cout << "NO" << endl; return 0;} }}}cout<<"YES"<<endl;
return 0;return 0;
}

经过这个想一下如果八个方向呢?

我开始的时候是思考的是八个方向,最开始的时候想的没有那么完善,是这样的

num = 0;
                if (0 != arr[i][j + 1]) num++;// 右
                if (0 != arr[i][j - 1]) num++;//左
                if (0 != arr[i+1][j]) num++;//下
                if (0 != arr[i-1][j]) num++;//上
                if (0 != arr[i+1][j + 1]) num++; //右下
                if (0 != arr[i+1][j-1]) num++;//左下
                if (0 != arr[i-1][j + 1]) num++; //左下
                if (0 != arr[i-1][j - 1]) num++;//左上
                //if (num > 6&&arr[i][j]!=0) cout << arr[i][j]<<endl;
                if (num > 6 && arr[i][j] != 0) flag = 1;

我对八个方向来分析,如果说 他们在这个方向上有不是0的那就说明没有病毒,当没有病毒是的个数大于六时候说明就不能被感染,然后我前边还设置一个flag呢,只要有一个不被感染那就说明不被感染,那就当然是 NO 下面的这个不完整哈,只是一个想法而已,仅供参考

#include <iostream>
#include <iomanip>
#define N 101
using namespace std;
int main()
{int arr[N][N];int n,m,i,j,t=1,x,y,num,flag=0;cin >> n>>m; for (i = 1; i <= n; i++){for (j = 1; j <= n; j++){arr[i][j]=t++;}}while (m > 0) {cin >> x >> y;arr[x][y] = 0;m--;}for (i = 1; i <= n; i++){for (j = 1; j <= n; j++){num = 0;if (0 != arr[i][j + 1]) num++;// 右if (0 != arr[i][j - 1]) num++;//左if (0 != arr[i+1][j]) num++;//下if (0 != arr[i-1][j]) num++;//上if (0 != arr[i+1][j + 1]) num++; //右下if (0 != arr[i+1][j-1]) num++;//左下if (0 != arr[i-1][j + 1]) num++; //左下if (0 != arr[i-1][j - 1]) num++;//左上//if (num > 6&&arr[i][j]!=0) cout << arr[i][j]<<endl;if (num > 6 && arr[i][j] != 0) flag = 1;}}if (flag == 1) cout << "YES"<<endl;else cout << "NO" << endl;for (i = 1; i <= n; i++){for (j = 1; j <= n; j++){cout<< arr[i][j]<<setw(4);}cout <<"\n";}return 0;
}
1

这篇关于二维数组八个方向的判断--牛客刷题1023-病菌感染的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/789611

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用