2023-10-28:用go语言,给定一个n*m的二维矩阵,每个位置都是字符, U、D、L、R表示传送带的位置,会被传送到 : 上、下、左、右, . 、O分别表示空地、目标,一定只有一个目标点, 可以
2023-10-28:用go语言,给定一个n*m的二维矩阵,每个位置都是字符,
U、D、L、R表示传送带的位置,会被传送到 : 上、下、左、右,
. 、O分别表示空地、目标,一定只有一个目标点,
可以在空地上选择上、下、左、右四个方向的一个,
到达传送带的点会被强制移动到其指向的下一个位置。
如果越界直接结束,返回有几个点可以到达O点。
来自左程云。
答案2023-10-28:
go代码用chatgpt编写,不需要修改。
c++代码用讯飞星火编写,略有改动。
大体步骤如下:
首先,代码定义了两个函数number1和number2,它们都接受一个二维矩阵作为输入,并返回一个整数,表示可以到达目标点O的点的数量。这两个函数的主要区别在于它们的搜索策略不同。number1使用深度优先搜索(DFS)策略,而number2使用广度优先搜索(BFS)策略。
在number1函数中,首先初始化一个与输入矩阵大小相同的visited矩阵,用于记录每个位置是否已经被访问过。然后,遍历输入矩阵,找到第一个目标点O,将其位置添加到队列queue中,并将visited对应位置设为true。接下来,从队列中取出一个位置,如果该位置是目标点O,则计数器ans加1;否则,检查该位置的上下左右四个相邻位置,如果相邻位置在矩阵范围内且未被访问过,则将其添加到队列中,并将visited对应位置设为true。重复这个过程,直到队列为空。最后,返回计数器ans的值。
在number2函数中,同样首先初始化一个与输入矩阵大小相同的visited矩阵,用于记录每个位置是否已经被访问过。然后,遍历输入矩阵,找到第一个目标点O,将其位置添加到队列queue中,并将visited对应位置设为true。接下来,从队列中取出一个位置,如果该位置是目标点O,则计数器ans加1;否则,检查该位置的上下左右四个相邻位置,如果相邻位置在矩阵范围内且未被访问过,则将其添加到队列中,并将visited对应位置设为true。重复这个过程,直到队列为空。最后,返回计数器ans的值。
generateRandomMap函数用于生成一个随机的nm二维矩阵,其中包含字符U、D、L、R、.和O。它首先创建一个大小为nm的二维数组mapData,然后遍历这个数组,对于每个位置,随机选择一个字符填充。最后,将一个随机位置设置为字符O。
在main函数中,首先设置随机数种子,然后进行多次测试。每次测试,调用generateRandomMap函数生成一个随机矩阵,然后分别调用number1和number2函数计算可以到达目标点O的点的数量,如果两者的结果不相等,则输出出错信息。最后,输出测试结束的信息。
总的时间复杂度为O(nm),因为需要遍历整个矩阵。总的额外空间复杂度为O(nm),因为需要存储visited矩阵和队列queue。
go完整代码如下:
package main
import (
"fmt"
"math/rand"
"time"
)
// 暴力方法
func number1(mapData [][]byte) int {
ans := 0
n := len(mapData)
m := len(mapData[0])
visited := make([][]bool, n)
for i := 0; i < n; i++ {
visited[i] = make([]bool, m)
}
for i := 0; i < n; i++ {
for j := 0; j < m; j++ {
if dfs(mapData, i, j, visited) {
ans++
}
}
}
return ans
}
// 暴力方法
func dfs(mapData [][]byte, i, j int, visited [][]bool) bool {
if i < 0 || i == len(mapData) || j < 0 || j == len(mapData[0]) || visited[i][j] {
return false
}
visited[i][j] = true
ans := false
if mapData[i][j] == 'O' {
ans = true
} else {
if mapData[i][j] == 'U' {
ans = dfs(mapData, i-1, j, visited)
} else if mapData[i][j] == 'D' {
ans = dfs(mapData, i+1, j, visited)
} else if mapData[i][j] == 'L' {
ans = dfs(mapData, i, j-1, visited)
} else if mapData[i][j] == 'R' {
ans = dfs(mapData, i, j+1, visited)
} else {
ans = dfs(mapData, i-1, j, visited) || dfs(mapData, i+1, j, visited) || dfs(mapData, i, j-1, visited) || dfs(mapData, i, j+1, visited)
}
}
visited[i][j] = false
return ans
}
// 正式方法
func number2(mapData [][]byte) int {
n := len(mapData)
m := len(mapData[0])
visited := make([][]bool, n)
for i := 0; i < n; i++ {
visited[i] = make([]bool, m)
}
queue := make([][2]int, n*m)
l := 0
r := 0
ans := 0
for i := 0; i < n; i++ {
for j := 0; j < m; j++ {
if mapData[i][j] == 'O' {
visited[i][j] = true
queue[r][0] = i
queue[r][1] = j
r++
break
}
}
}
for l < r {
ans++
cur := queue[l]
row := cur[0]
col := cur[1]
if row-1 >= 0 && !visited[row-1][col] && (mapData[row-1][col] == 'D' || mapData[row-1][col] == '.') {
visited[row-1][col] = true
queue[r][0] = row - 1
queue[r][1] = col
r++
}
if row+1 < n && !visited[row+1][col] && (mapData[row+1][col] == 'U' || mapData[row+1][col] == '.') {
visited[row+1][col] = true
queue[r][0] = row + 1
queue[r][1] = col
r++
}
if col-1 >= 0 && !visited[row][col-1] && (mapData[row][col-1] == 'R' || mapData[row][col-1] == '.') {
visited[row][col-1] = true
queue[r][0] = row
queue[r][1] = col - 1
r++
}
if col+1 < m && !visited[row][col+1] && (mapData[row][col+1] == 'L' || mapData[row][col+1] == '.') {
visited[row][col+1] = true
queue[r][0] = row
queue[r][1] = col + 1
r++
}
l++
}
return ans
}
// 生成随机地图
func generateRandomMap(n, m int) [][]byte {
mapData := make([][]byte, n)
for i := 0; i < n; i++ {
mapData[i] = make([]byte, m)
for j := 0; j < m; j++ {
r := rand.Intn(5)
if r == 0 {
mapData[i][j] = 'U'
} else if r == 1 {
mapData[i][j] = 'D'
} else if r == 2 {
mapData[i][j] = 'L'
} else if r == 3 {
mapData[i][j] = 'R'
} else {
mapData[i][j] = '.'
}
}
}
mapData[rand.Intn(n)][rand.Intn(m)] = 'O'
return mapData
}
func main() {
rand.Seed(time.Now().UnixMicro())
n := 10
m := 10
testTimes := 10000
fmt.Println("测试开始")
for i := 0; i < testTimes; i++ {
mapData := generateRandomMap(n, m)
ans1 := number1(mapData)
ans2 := number2(mapData)
if ans1 != ans2 {
fmt.Println("出错了!")
}
}
fmt.Println("测试结束")
}

c++完整代码如下:
#include <iostream>
#include <vector>
#include <queue>
#include <cstdlib>
#include <ctime>
using namespace std;
bool dfs(vector<vector<char>>& map, int i, int j, vector<vector<bool>>& visited);
vector<vector<char>> generateRandomMap(int n, int m);
// 暴力方法
int number1(vector<vector<char>>& map) {
int ans = 0;
int n = map.size();
int m = map[0].size();
vector<vector<bool>> visited(n, vector<bool>(m, false));
for (int i = 0; i < map.size(); i++) {
for (int j = 0; j < map[0].size(); j++) {
if (dfs(map, i, j, visited)) {
ans++;
}
}
}
return ans;
}
// 暴力方法
bool dfs(vector<vector<char>>& map, int i, int j, vector<vector<bool>>& visited) {
if (i < 0 || i == map.size() || j < 0 || j == map[0].size() || visited[i][j]) {
return false;
}
visited[i][j] = true;
bool ans = false;
if (map[i][j] == 'O') {
ans = true;
}
else {
if (map[i][j] == 'U') {
ans = dfs(map, i - 1, j, visited);
}
else if (map[i][j] == 'D') {
ans = dfs(map, i + 1, j, visited);
}
else if (map[i][j] == 'L') {
ans = dfs(map, i, j - 1, visited);
}
else if (map[i][j] == 'R') {
ans = dfs(map, i, j + 1, visited);
}
else {
ans = dfs(map, i - 1, j, visited) || dfs(map, i + 1, j, visited) || dfs(map, i, j - 1, visited)
|| dfs(map, i, j + 1, visited);
}
}
visited[i][j] = false;
return ans;
}
// 正式方法
int number2(vector<vector<char>>& map) {
int n = map.size();
int m = map[0].size();
vector<vector<bool>> visited(n, vector<bool>(m, false));
vector<pair<int, int>> queue(n * m);
int l = 0;
int r = 0;
int ans = 0;
// O在哪,目的地
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (map[i][j] == 'O') {
visited[i][j] = true;
queue[r++] = make_pair(i, j);
break;
}
}
}
// [] [] [] [] [] ...
// l ...... r
while (l < r) { // 队列里还有位置!
ans++;
pair<int, int> cur = queue[l++];
int row = cur.first;
int col = cur.second;
if (row - 1 >= 0 && !visited[row - 1][col] && (map[row - 1][col] == 'D' || map[row - 1][col] == '.')) {
visited[row - 1][col] = true;
queue[r++] = make_pair(row - 1, col);
}
if (row + 1 < n && !visited[row + 1][col] && (map[row + 1][col] == 'U' || map[row + 1][col] == '.')) {
visited[row + 1][col] = true;
queue[r++] = make_pair(row + 1, col);
}
if (col - 1 >= 0 && !visited[row][col - 1] && (map[row][col - 1] == 'R' || map[row][col - 1] == '.')) {
visited[row][col - 1] = true;
queue[r++] = make_pair(row, col - 1);
}
if (col + 1 < m && !visited[row][col + 1] && (map[row][col + 1] == 'L' || map[row][col + 1] == '.')) {
visited[row][col + 1] = true;
queue[r++] = make_pair(row, col + 1);
}
}
return ans;
}
// 生成随机地图
vector<vector<char>> generateRandomMap(int n, int m) {
vector<vector<char>> map(n, vector<char>(m));
srand(time(0));
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
int r = rand() % 5;
if (r == 0) {
map[i][j] = 'U';
}
else if (r == 1) {
map[i][j] = 'D';
}
else if (r == 2) {
map[i][j] = 'L';
}
else if (r == 3) {
map[i][j] = 'R';
}
else {
map[i][j] = '.';
}
}
}
map[rand() % n][rand() % m] = 'O';
return map;
}
// 为了测试
int main() {
int n = 10;
int m = 10;
int testTimes = 1000;
cout << ("测试开始") << endl;
for (int i = 0; i < testTimes; i++) {
vector<vector<char>> map = generateRandomMap(n, m);
int ans1 = number1(map);
int ans2 = number2(map);
if (ans1 != ans2) {
cout << ("出错了!") << endl;
}
}
cout << ("测试结束") << endl;
return 0;
}

2023-10-28:用go语言,给定一个n*m的二维矩阵,每个位置都是字符, U、D、L、R表示传送带的位置,会被传送到 : 上、下、左、右, . 、O分别表示空地、目标,一定只有一个目标点, 可以的更多相关文章
- 旋转图像 给定一个 n × n 的二维矩阵表示一个图像。
给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 : 给定 ma ...
- js实现Mac触摸板双指事件(上/下/左/右/放大/缩小)
前言 这几天在修复一个web问题时,需要捕获Mac触摸板双指事件(上.下.左.右.放大.缩小),但发现并没有现成的轮子,还是要自己造. 例如:jquery.mousewheel.js(添加跨浏览器的鼠 ...
- 【leetcode-03】给定一个字符串,请你找出其中不含有重复字符的最长子串的长度
开个新坑,leetcode上面做题目.下面是题目描述: <!-- 给定一个字符串,请你找出其中不含有重复字符的最长子串的长度. 示例 1: 输入: "abcabcbb" 输出 ...
- [LeetCode] Search a 2D Matrix II 搜索一个二维矩阵之二
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- [LeetCode] 240. Search a 2D Matrix II 搜索一个二维矩阵 II
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- [LeetCode] Search a 2D Matrix 搜索一个二维矩阵
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- [LeetCode] 74. Search a 2D Matrix 搜索一个二维矩阵
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- IT公司100题-35- 求一个矩阵中最大的二维矩阵(元素和最大)
问题描述: 求一个矩阵中最大的二维矩阵(元素和最大).如: 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 中最大的是: 4 5 9 10 分析: 2*2子数组的最大和.遍历求和,时 ...
- 用Python+qrcode库创建一个包含信息的二维码
安装qrcode库和PIL库 在命令行中分别输入pip install qrcode 和pip install pillow 导入库格式如下: import PIL import qrcode 下面以 ...
- [CareerCup] 11.6 Search a 2D Matrix 搜索一个二维矩阵
11.6 Given an M x N matrix in which each row and each column is sorted in ascending order, write a m ...
随机推荐
- 在macOS上,可以使用以下步骤来清理本地多个版本的Python:
确认已经安装了Homebrew 如果您还没有安装Homebrew,可以在终端中运行以下命令进行安装: /bin/bash -c "$(curl -fsSL https://raw.githu ...
- .Net析构函数再论(CLR源码级的剖析)
前言 碰到一些问题,发觉依旧没有全面了解完全析构函数.本篇继续看下析构函数的一些引申知识. 概述 析构函数目前发现的总共有三个标记,这里分别一一介绍下.先上一段代码: internal class P ...
- Visible Lattice Points 题解
Visible Lattice Points 题目大意 给定一个 \(N×N×N\) 的由若干点组成的立方体,点的坐标从 \((0,0,0)\) 到 \((N,N,N)\),求从点 \((0,0,0) ...
- 虹科干货| 虹科Redis企业版数据库:告别游戏卡顿,让快乐加速!
"卡顿一分钟,玩家两行泪" 游戏已成为年轻人最主要的消遣娱乐方式之一,游戏卡顿给玩家带来糟糕游戏体验背后的原因是什么?数据存储与查询速度不够快! 游戏开发领域,不仅拥有海量的数 ...
- 搞懂闭包JavaScript的GC机制
其实不管什么语言,都有一套垃圾回收机制.为什么要有垃圾回收机制?因为内存,程序运行需要内存,如果没有垃圾回收(循环引用,内存泄漏),那么内存占用就会越来越高,轻点说会影响性能卡顿,严重的直接导致崩溃. ...
- JVM-JVM如何加载类
一.Java 语言的类型可以分为两大类: 基本类型(primitive types) 引用类型(reference types):类.接口.数组类和泛型参数(泛型参数会在编译中被擦除),因此Java虚 ...
- 题解 SP13015
题目描述: 给定初始序列 \(A\),然后对原序列有以下操作: 操作 \(1\): 0 l r v 将区间 \([l,r]\) 全赋值为 \(v\). 操作 \(2\):1 l r 查询区间 \([l ...
- mysql group by 执行原理及千万级别count 查询优化
大家好,我是蓝胖子,前段时间mysql经常碰到慢查询报警,我们线上的慢sql阈值是1s,出现报警的表数据有 7000多万,经常出现报警的是一个group by的count查询,于是便开始着手优化这块, ...
- 下载神器——you-get
下载神器--you-get 01. you-get下载 you-get是一个基于Python3开发的开源项目. 某些网站的音视频资源,本身不提供下载功能,通过you-get,可以通过几条简单的命令去下 ...
- 【封装】Splay
注意确保操作合法性,否则可能陷入死循环 以点权作为排序依据 struct Splay{ #define ls p[u].son[0] #define rs p[u].son[1] #define ma ...