利用链表来写一个贪吃蛇小demo

利用链表来写一个贪吃蛇小demo

# 大家好,我是北京菜鸟在线的unity3d高级讲师范老师。今天来给大家讲如何 利用链表来写一个贪吃蛇小demo

手写一个链表

一:根据难度分为:

  一级:   数组      链表   (最基本的)

  二级:   栈          队列

  三级:       二叉树   (国企经常考,unity3d很少考)

  四级:         图

原理: 数组: char[] arr = new char[10];
表示在内存的空间是连续的空间。 一个字节是 8位,char是一个字节。
int有时候占4个字节(在Win32)
链表:连续的分存在不同的内存中,不同的空间,找到第一个,才能找到第二个....
链表缺点:通过下标去一个节点是非常复杂的,(检索效率底下)

二:手写一个链表,创建一个新的场景,把下面的脚本放在摄像机上,运行后观察输出,代码如下:

using UnityEngine;

using System.Collections;

using System.Collections.Generic;

public class StudentList : MonoBehaviour{8

// 自己手动书写一个链表

public class Student {     // 链表的每个节点,每个节点都有自己的名字,每个节点都知道自己下个节点是谁-。
    public string mName;
    public Student mNext;

    public Student(string name) {
        mName = name;
    }

}
private Student mTopStudent = null;    // 永远指向第一个学生
private Student mPreSrudent = null;    // 一只指向最后一个学生
private int mCount = 0;               // 当前有多少个学生

void Start()
{
    Student stu1 = new Student( "小红");
    Add(stu1);

    Student stu2 = new Student( "小黑");
    Add(stu2);

    Student stu3 = new Student( "小白");
    Add(stu3);    //添加到链表里面

    Student stu4 = new Student( "小明");
    Add(stu4,1);
    print(Search(1).mNext.mName);

    print( "当前最后一个学生是" + mPreSrudent.mName);
    print( "当前总共有" + mCount + "个学生");
    print( "第三个学生的名字是:" + Search(3));
    print( "查询名字叫小黑的他是第" + SearchNo("小黑" + "个"));
    print( "查询名字叫小蓝的他是第" + SearchNo("小蓝" + "个"));
}

void Add(Student stu)   // 链表添加一个节点,通过链表添加一个学生
{
    if (mPreSrudent == null )
    {
        mTopStudent = stu;
        mPreSrudent = stu;
    }
    else {
        mPreSrudent.mNext = stu;
        mPreSrudent = stu;
    }
    mCount++;
}

Student Search(int   no)   //找到第几个学生,通过学号找学生的名字。
{
    Student temp = mTopStudent;
    for(int i = 1; i < no; i++ )
    {
       temp = temp.mNext;
    }
    return temp;
}

int SearchNo(string name)    //通过学生名字去找学生的学号
{
   Student temp = mTopStudent;
   int index = 1;
   while (temp.mName != name)
   {
       temp = temp.mNext;
       index++;
       if (index >= mCount)
       {
           print( "没有这个学生" );
           return -1;
       }
   }
   return index;
}

void Add(Student stu, int index)    //往指定位置插入一个学生
{
    if (index == mCount)
    {
        Add(stu);
    }
    else {
        Student temp = Search(index);  // 找到他要a插在那个学生后面,找到那个学生
        Student tempNext = temp.mNext;   // 把到找到的那个不宪政的下一个学生存起e来。
        temp.mNext = stu;               //找到先前的那个学生让他的下个学生等于新来的学生
        stu.mNext = tempNext;           //让新来的学生的下一个学生等于先前那个学生的下一个学生
    }
}

}

三:利用链表在unity3d 里写一个贪吃蛇的小demo, 图形如下:

3-1:

3-2:

3-3:

3-4:蛇头脚本的代码如下:

using UnityEngine;
using System.Collections;
public class SnakeNead : MonoBehaviour
{
private float mTime = 0.3f;
public SnakeBody mBody;
private Vector3 mPos; //把头的位置存储起来
private Quaternion mRot; //把当前头的旋转存储起来
private SnakeBody mTailBody; //相对于第三个,第二个是头
public SnakeBody mOrion; //需要生成的子体
// Use this for initialization
void Start () {
mTailBody = mBody;
}

             // Update is called once per frame
             void Update () {
    if (Input .GetKeyDown(KeyCode.W))
    {
        this.transform.eulerAngles = new Vector3(0, 0, 0);
    }
    if (Input .GetKeyDown(KeyCode.S))
    {
        this.transform.eulerAngles = new Vector3(0,180,0);
    }
    if (Input .GetKeyDown(KeyCode.D))
    {
        this.transform.eulerAngles = new Vector3(0,90,0);
    }
    if (Input .GetKeyDown(KeyCode.A))
    {
        this.transform.eulerAngles = new Vector3(0,270,0);
    }
    if (mTime > 0)
    {
        mTime -= Time.deltaTime;
        if (mTime <= 0)
        {
            mPos = this.transform.position;   // 把当前位置赋值给mPos
            mRot = this.transform.rotation;   // 头旋转值,赋值给 mPot
            this.transform.Translate(Vector3 .forward);
            mBody.SetPos(mPos,mRot);
            mTime = 0.3f;
        }
    }
    if (Input .GetKeyDown(KeyCode.G))
    {
        SnakeBody body =  (SnakeBody )Instantiate(mOrion);
        mTailBody.mNext = body;
        mTailBody = body;
    }
            }

}

3-5 : 蛇头的下个身子的代码如下:

using UnityEngine;
using System.Collections;
// 贪吃蛇, 把头的位置和旋转先进行存储,然后,把身子的位置和旋转,使1用它们两个相等。赋予
public class SnakeBody : MonoBehaviour {
public SnakeBody mNext;
private Vector3 mPos;
private Quaternion mRot;
public void SetPos(Vector3 pos , Quaternion rot)
{
mPos = this.transform.position;
mRot = this.transform.rotation;
this.transform.position = pos;
this.transform.rotation = rot;
if (mNext != null )
{
mNext.SetPos(mPos,mRot);
}
}
// Use this for initialization
void Start () {

            }

             // Update is called once per frame
             void Update () {

            }

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容