剑指offer(三)从尾到头打印链表
2018-07-28 本文已影响11人
z七夜
写在前面:
为了增长一下自己的数据结构能力,也为了面试准备,准备将剑指Offer做一下,并与各位分享,希望各位可以对代码以及思路提提建议,欢迎志同道合者,谢谢。
1.剑指offer(一)二维数组中的查找
2.剑指offer(二) 替换空格
题目:
输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。
思路:
输入一个链表,将链表遍历出来,用集合接受,然后翻转集合,那么就是倒着的链表,
本来是想着能不能直接从链表的尾部开始倒着遍历,直接添加到集合,但是想了一下,还是要各位帮帮忙,
代码实现
package com.itzmn.offer;
import java.util.ArrayList;
import java.util.Collections;
/**
* @Auther: 张梦楠
* @Date: 2018/7/27 18:41
* 简书:https://www.jianshu.com/u/d611be10d1a6
* 码云:https://gitee.com/zhangqiye
* @Description:
*/
public class Offer3 {
public static void main(String[] args) {
new Offer3().init();
}
private void init() {
ListNode listNode = new ListNode(2);
ListNode listNode1 = new ListNode(3);
ListNode listNode3 = new ListNode(4);
listNode.next = listNode1;
listNode1.next = listNode3;
ArrayList<Integer> integers = printListFromTailToHead(listNode);
for (Integer integer:integers){
System.out.println(integer);
}
}
public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
ArrayList<Integer> integers = new ArrayList<>();
while (listNode != null){
integers.add(listNode.val);
listNode = listNode.next;
}
Collections.reverse(integers);
return integers;
}
class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}
}
希望大家可以多多指点,优化一下,
QQ群:552113611