纳金网
标题:
消星星的同颜色算法
[打印本页]
作者:
may
时间:
2019-12-15 10:16
标题:
消星星的同颜色算法
[backcolor=rgba(255, 255, 255, 0.8)]
参考:
[backcolor=rgba(255, 255, 255, 0.8)]
[url=]https://blog.csdn.net/dengminghli/article/details/84147675[/url]
int[] xx = { 1, 0, 0, -1 };
int[] yy = { 0, 1, -1, 0 };
int[,] visit = new int[10, 10];//为了防止重复访问
GameObject[] objList = new GameObject[10 * 10];//用来保存相同颜色的色块
GameObject[,] curObj = new GameObject[10 , 10];//当前所有的方个中的颜色
int index = 0;//计数
void HellowWorld(GameObject obj)
{
//获得当前色块的坐标
int x = (int)obj.transform.position.x;
int y = (int)obj.transform.position.y;
visit[x, y] = 1;//1表示访问过这个色块
objList[index++] = obj;//添加当前颜色块
//循环,实现四个方向的轮询
for (int i = 0; i < 4; i++)
{
//获取第一个方向:根据xx和yy的顺序调整
int x1 = x + xx[i];
int y1 = y + yy[i];
if (x1 >= 0 && x1 < 10 && y1 >= 0 && y1 < 10)//判断出界
{
if (visit[x1, y1] == 0 && curObj[x1, y1].name == obj.name)//没有访问过,如果符合相同颜色
{
HellowWorld(curObj[x1,y1]);
}
}
}
}
复制代码
欢迎光临 纳金网 (http://rs.narkii.com/club/)
Powered by Discuz! X2.5