链表|合并两个有序的单链表,合并之后的链表依然有序

【尚硅谷-韩顺平-数据结构与算法(Java解释版)-链表-课后练习.】

题目:合并两个有序的单链表,合并之后的链表依然有序

解题要点:

1.写一个链表增加方法

2.要断开要添加的节点后面的节点,而不是抛掉(如果不理解,需增加对链表认识)

public class ListTest1 {
    public static void main(String[] args) {
        Hero hero = new Hero(1,"林欢喜","戏法王子");
        Hero hero2 = new Hero(21,"赵云","赵子龙");
        Hero hero3 = new Hero(6,"马云","马首富");
        Hero hero4 = new Hero(77,"任正非","华为一哥");
        Hero hero6 = new Hero(3,"赵本山","本山大叔");
        Hero hero5 = new Hero(28,"澎湖湾","她的家");
        Hero hero7 = new Hero(47,"乔布斯","乔不死");
        Hero hero8 = new Hero(70,"爱因斯坦","学术王者");
        HeroList heroList = new HeroList();
        HeroList heroList1 = new HeroList();
        heroList.addHero(hero4);
        heroList.addHero(hero2);
        heroList.addHero(hero);
        heroList.addHero(hero3);

        heroList1.addHero(hero5);
        heroList1.addHero(hero6);
        heroList1.addHero(hero7);
        heroList1.addHero(hero8);

        Hero nextHero = heroList1.getHeadHero().nextHero;
        //这道题的难点是要断开要添加的节点后面的节点,而不是抛掉
        //如果不做处理直接把另一个链表的节点添加进去,会引导致无法正确读取到后续节点
        
        Hero middle = new Hero();
        middle = null;
        while (nextHero != null){
        //把要添加的节点后续的节点放在一个新的对象里面,之后要用;
        //为要放在新对象里而不是直接用nextHero呢?因为在讲nextHero放入链表时,链表的放入
        //方法改变了nextHero的内部的指针,无法通过改变后的nextHero读取到另一个链表的节点
        //因此要把后续的节点保存在另一个对象中,即middle中,后续可以从middle中读取到另一个
        //链表后续的节点
            middle = nextHero.nextHero;
            nextHero.nextHero = null;
            heroList.addHero(nextHero);
            nextHero = middle;
        }
        heroList.listHero();
    }
}

class HeroList{
    private Hero headHero = new Hero(0,"","");

    public void listHero(){
        Hero temp = headHero;
        while(true){
            if(headHero.nextHero == null){
                System.out.println("空list");
                break;
            }
            if(temp.nextHero == null){
                break;
            }
            temp = temp.nextHero;
            System.out.println(temp);
        }
    }

    public void addHero(Hero hero){
        Hero temp = headHero;
        boolean flag = false;
        while (true){
            if(temp.nextHero == null){
                //说明链表到头了
                break;
            }
            if(temp.nextHero.getId() > hero.getId()){
                flag = true;
                break;
            }
            temp = temp.nextHero;
        }
        if(flag){
            //进入代表是插入

            //拆开指针,放入数据
            hero.nextHero = temp.nextHero;
            temp.nextHero = hero;

        }else {
            //进入代表链表是尾部添加
            temp.nextHero = hero;
        }

    }

    public Hero getHeadHero() {
        return headHero;
    }

}
class Hero{
    private Integer id;
    private String name;
    private String nickName;
    public Hero  nextHero;

    public Hero() {
    }

    @Override
    public String toString() {
        return "Hero{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", nickName='" + nickName + '\'' +
                '}';
    }

    public Hero(Integer id, String name, String nickName) {
        this.id = id;
        this.name = name;
        this.nickName = nickName;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getNickName() {
        return nickName;
    }

    public void setNickName(String nickName) {
        this.nickName = nickName;
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值