当前位置: 首页 > news >正文

做外贸哪个网站可以接单上海网络推广教程

做外贸哪个网站可以接单,上海网络推广教程,网络营销的原理,做园林景观的网站题目: 设想有个机器人坐在一个网格的左上角,网格 r 行 c 列。机器人只能向下或向右移动,但不能走到一些被禁止的网格(有障碍物)。设计一种算法,寻找机器人从左上角移动到右下角的路径。 网格中的障碍物和空…

题目:

设想有个机器人坐在一个网格的左上角,网格 r 行 c 列。机器人只能向下或向右移动,但不能走到一些被禁止的网格(有障碍物)。设计一种算法,寻找机器人从左上角移动到右下角的路径。

网格中的障碍物和空位置分别用 1 和 0 来表示。

返回一条可行的路径,路径由经过的网格的行号和列号组成。左上角为 0 行 0 列。如果没有可行的路径,返回空数组。

示例 1:

输入:
[[0,0,0],[0,1,0],[0,0,0]
]
输出: [[0,0],[0,1],[0,2],[1,2],[2,2]]
解释: 
输入中标粗的位置即为输出表示的路径,即
0行0列(左上角) -> 0行1列 -> 0行2列 -> 1行2列 -> 2行2列(右下角)

说明:r 和 的值均不超过 100。

思路:

  1. 深度优先(DFS)寻找终点。
  2. 使用visited数组记录走过的路径
  3. 发现不可行的路径就回溯,直到到达终点

以下C代码有参考题解区大佬:taopi

/*** Return an array of arrays of size *returnSize.* The sizes of the arrays are returned as *returnColumnSizes array.* Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().*/int visited[100][100];
int DFS(int** obstacleGrid, int r, int c, int x, int y, int** ret, int* len) {// 碰到边界或者障碍,或者重复到达if(x >= r || y >= c || obstacleGrid[x][y] || visited[x][y]){return 0;}ret[*len][0] = x;ret[(*len)++][1] = y;// 到达终点if(x == r - 1 && y == c - 1) {return 1;}visited[x][y] = 1;// 下或者右 有路可走if(DFS(obstacleGrid, r, c, x, y + 1, ret, len) || DFS(obstacleGrid, r, c, x + 1, y, ret, len)){return 1;}// 无路可走,回溯(*len)--;return 0;
}int** pathWithObstacles(int** obstacleGrid, int obstacleGridSize, int* obstacleGridColSize, int* returnSize, int** returnColumnSizes) {*returnSize = 0;int r = obstacleGridSize, c = *obstacleGridColSize;if(r == 0 || c == 0 || obstacleGrid[0][0] || obstacleGrid[r-1][c-1]) {return NULL;}int** ret = malloc(sizeof(int*) * (r + c));for(int i = 0; i < r + c; i++){ret[i] = malloc(sizeof(int) * 2);}int len = 0;memset(visited, 0, sizeof(visited));if(DFS(obstacleGrid, r, c, 0, 0, ret, &len)) {*returnSize = len;*returnColumnSizes = (int*)malloc(sizeof(int) * len);for(int i = 0; i < len; i++) {(*returnColumnSizes)[i] = 2;}return ret;}for(int i = 0; i < r + c; i++){free(ret[i]);}free(ret);return NULL;
}

http://www.yayakq.cn/news/443558/

相关文章:

  • 百度怎么推广网站wordpress托管服务器
  • 网站结构怎么做互联网金融p2p网站建设
  • 电影网站做淘宝联盟江门公司网站建设
  • 企业门户网站用户类型杭州网站建设招聘网
  • 用vs2010做网站的好处做网站要钱嘛
  • 网站宣传与推广的方法手机版网站源码
  • 怎么做微信小说网站吗做娃衣的布料去哪个网站
  • 集团网站设计开发公司广告墙设计图片
  • 静态网站可以申请域名吗支付宝网站开发流程
  • 公司网站被侵权价格列表 wordpress
  • 网站建设与管理论文的总结wordpress插件 数据
  • 平面设计兼职网站centos wordpress 安装
  • 网站开发怎么报价域名解析工具
  • 信息分类网站建设电脑版网站转手机版怎么做
  • 做卖蜂蜜的网站计划书哪个网站可以做彩经专家
  • 视频制作网站素材施工企业安全生产考核评定等级分为
  • 建设银行积分兑换商城网站请叫我鬼差大人王烨
  • 网站免费推广外贸建站与推广如何做手机壳
  • 有哪些网站可以做视频华为al00手机价格是多少钱
  • 小说网站怎么做权重wordpress 国内教育主题
  • 三丰云怎么做网站安徽网站制作
  • 宝丰网站制作公司上海建设银行官网网站6
  • 九龙坡建站公司商业计划书模板范文
  • 建立wordpress网站吗网站数据库安全
  • 怎么查网站服务器校园网站制作
  • 网站用词精准性网站建设制作方法
  • 网站建设步骤详解郑州网站推广哪家好
  • 姑苏区网站建设可以做同城活动的网站
  • 耳机商城网站开发北京企业网站设计公司
  • 外贸网站屏蔽国内ip金石项目管理软件