您的位置:首页 > 编程语言 > Java开发

Java实现简单的链表(钢铎的烽火)

2018-02-05 17:36 453 查看
因为Java里的对象名本身是一个引用类型,类似于C里面的指针,所以可以很简单地拿来指向下一个节点。

我们以钢铎的烽火为例,从尾巴插入节点,从头依次点燃烽火!参考《Java程序设计 基础、编程抽象与算法策略》

/*
* File: BeaconsOfGondor.java
* --------------------------
* This program illustrates the concept of a linked list by simulating the
* Beacons of Gondor story from J. R. R. Tolkien's Return of the King.
*/

public class BeaconsOfGondor {

public void run() {
Tower rohan = createTower("Rohan", null);
Tower halifirien = createTower("Halifirien", rohan);
Tower calenhad = createTower("Calenhad", halifirien);
Tower minRimmon = createTower("Min-Rimmon", calenhad);
Tower erelas = createTower("Erelas", minRimmon);
Tower nardol = createTower("Nardol", erelas);
Tower eilenach = createTower("Eilenach", nardol);
Tower amonDin = createTower("Amon Din", eilenach);
Tower minasTirith = createTower("Minas Tirith", amonDin);
signal(minasTirith);
}

/* Creates a new Tower object from its name and link fields */

private Tower createTower(String name, Tower link) {
Tower t = new Tower();
t.name = name;
t.link = link;
return t;
}

/* Generates a signal starting at start and propagating down the chain */

private void signal(Tower start) {
for (Tower cp = start; cp != null; cp = cp.link) {
System.out.println("Lighting " + cp.name);
}
}

/* Defines an inner class named Tower that acts as a cell in a linked list */

private static class Tower {
String name;                  /* The name of this tower              */
Tower link;                   /* Link to the next tower in the chain */
}

/* Main program */

public static void main(String[] args) {
new BeaconsOfGondor().run();
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Java alogrithm