数据结构之——图论中常用的方向数组是如何定义的

目录

一、先搞懂坐标系

二、方向数组的标准格式

三、实际运用方面:

①顺时针:

[✅ 最终标准顺时针方向数组:](#✅ 最终标准顺时针方向数组:)

②逆时针:

逆时针方向数组定义

[✅ 最终标准逆时针方向数组](#✅ 最终标准逆时针方向数组)


一、先搞懂坐标系

代码里的二维数组是矩阵坐标系 ,和数学坐标系不一样【方向不一样】:

数学坐标系: 矩阵坐标系:

  • x行号(上下移动)
  • y列号(左右移动)

规则:

  • 向下走x + 1
  • 向上走x - 1
  • 向右走y + 1
  • 向左走y - 1

二、方向数组的标准格式

方向数组固定是 2 个数组,各 4 个值 ,对应 4 个方向

定义的时候这样写:dx[i]dy[i]一对 ,代表第 i 个方向

三、实际运用方面:

如果是顺时针进行转: 如果是逆时针进行转:

①顺时针:

顺时针顺序固定是:右 → 下 → 左 → 上(也可以是其他起始方向,这里以最直观的 "先右再顺时针绕圈" 为例)

对应变化:

  1. 向右:x 不变,y+1 → dx=0, dy=1
  2. 向下:x+1,y 不变 → dx=1, dy=0
  3. 向左:x 不变,y-1 → dx=0, dy=-1
  4. 向上:x-1,y 不变 → dx=-1, dy=0

✅ 最终标准顺时针方向数组:

复制代码
int dx[4] = {0, 1, 0, -1};
int dy[4] = {1, 0, -1, 0};

x+=dx[];y+=dy[]

②逆时针:

逆时针方向数组定义

逆时针顺序固定是:右 → 上 → 左 → 下(也可以是其他起始方向,这里以最直观的 "先右再逆时针绕圈" 为例)

对应变化:

  1. 向右 :x 不变,y+1 → dx=0, dy=1
  2. 向上 :x-1,y 不变 → dx=-1, dy=0
  3. 向左 :x 不变,y-1 → dx=0, dy=-1
  4. 向下 :x+1,y 不变 → dx=1, dy=0

✅ 最终标准逆时针方向数组

复制代码
int dx[4] = {0, -1, 0, 1};  // 右、上、左、下(x方向变化)
int dy[4] = {1, 0, -1, 0};  // 右、上、左、下(y方向变化)

x+=dx[];y+=dy[]

相关推荐
CoderCodingNo7 小时前
【CSP】CSP-J 2019 江西真题 | 面积 luogu-P5681 (适合GESP一级、二级考生练习)
算法
Mr_pyx8 小时前
【LeetHOT100】合并两个有序链表——Java多解法详解
算法
yu85939588 小时前
利用MATLAB进行木材图像去噪
开发语言·算法·matlab
cpp_25018 小时前
P2722 [USACO3.1] 总分 Score Inflation
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
民乐团扒谱机8 小时前
【源码剖析】MATLAB混响函数底层逻辑拆解:Dattorro算法从公式到音频帧的完整推导
算法
淡海水8 小时前
【AI模型】概念-Token
人工智能·算法
凯瑟琳.奥古斯特8 小时前
数据结构核心知识点精要
数据结构·算法·排序算法
隔壁大炮8 小时前
Day02-04.张量点乘和矩阵乘法
人工智能·pytorch·深度学习·线性代数·算法·矩阵
王老师青少年编程8 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【删数问题】:删数问题
c++·算法·贪心·csp·信奥赛
geneculture9 小时前
本真信息观:基于序位守恒的融智学理论框架——人类认知第二次大飞跃的基础
人工智能·算法·机器学习·数据挖掘·融智学的重要应用·哲学与科学统一性·融智时代(杂志)