千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  應(yīng)聘面試  >  Java面試題  > 華為外包java面試題-Java實現(xiàn)單鏈表的逆序

華為外包java面試題-Java實現(xiàn)單鏈表的逆序

來源:千鋒教育
發(fā)布人:wjy
時間: 2023-07-25 15:04:27 1690268667

  假設(shè)你正在應(yīng)聘華為外包公司的Java開發(fā)崗位,以下是一個可能的面試題案例:

  面試題目:Java實現(xiàn)單鏈表的逆序

  問題描述:

  請編寫一個Java程序,實現(xiàn)對單鏈表的逆序操作。給定一個單鏈表的頭節(jié)點,要求將鏈表的所有節(jié)點反轉(zhuǎn),并返回反轉(zhuǎn)后的頭節(jié)點。

  示例:

  假設(shè)鏈表為:1 -> 2 -> 3 -> 4 -> 5

  反轉(zhuǎn)后應(yīng)該為:5 -> 4 -> 3 -> 2 -> 1

  解題思路:

  實現(xiàn)單鏈表的逆序操作可以使用迭代或遞歸的方法。下面將為大家提供使用迭代的解題思路。

  解題步驟:

  1. 定義三個指針:prev(記錄前一個節(jié)點)、current(記錄當(dāng)前節(jié)點)、next(記錄當(dāng)前節(jié)點的下一個節(jié)點)。

  2. 初始時,prev指向null,current指向頭節(jié)點。

  3. 在循環(huán)中,將current的next指針指向prev,然后將prev指向current,current指向next。

  4. 重復(fù)上述步驟,直到current指向null(到達鏈表的末尾)。

  Java代碼實現(xiàn):

class ListNode {
int val;
ListNode next;

ListNode(int val) {
this.val = val;
}
}

public class ReverseLinkedList {

public ListNode reverse(ListNode head) {
ListNode prev = null;
ListNode current = head;
ListNode next = null;

while (current != null) {
next = current.next; // 先保存當(dāng)前節(jié)點的下一個節(jié)點
current.next = prev; // 當(dāng)前節(jié)點的next指針指向前一個節(jié)點
prev = current; // prev指向當(dāng)前節(jié)點,相當(dāng)于前移一步
current = next; // current指向下一個節(jié)點,相當(dāng)于前移一步
}

return prev; // prev指向原鏈表的最后一個節(jié)點,即反轉(zhuǎn)后的頭節(jié)點
}

// 測試
public static void main(String[] args) {
ListNode head = new ListNode(1);
head.next = new ListNode(2);
head.next.next = new ListNode(3);
head.next.next.next = new ListNode(4);
head.next.next.next.next = new ListNode(5);

ReverseLinkedList solution = new ReverseLinkedList();
ListNode reversedHead = solution.reverse(head);

// 打印反轉(zhuǎn)后的鏈表
while (reversedHead != null) {
System.out.print(reversedHead.val + " -> ");
reversedHead = reversedHead.next;
}
System.out.print("null");
}
}

 

  這是一個典型的面試題目,面試官可能會根據(jù)你的解答展開更多問題,例如如何使用遞歸實現(xiàn)鏈表逆序,或者如何處理特殊情況(如空鏈表)。在面試過程中,除了正確的解答問題,展示良好的溝通和思考能力也是非常重要的。希望以上面試題案例對你有所幫助!

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
面向?qū)ο缶幊痰奶卣魇鞘裁?請解釋每個特征

答案:面向?qū)ο缶幊痰奶卣靼ǎ悍庋b(Encapsulation):封裝是將相關(guān)的數(shù)據(jù)和方法組合在一起形成類的機制。它可以隱藏內(nèi)部實現(xiàn)細節(jié),只暴露必要的...詳情>>

2023-07-18 13:56:00
容器是什么?如何理解容器

  容器(Container)是一個廣泛的概念,指的是一種可以容納其他元素或?qū)ο蟮臄?shù)據(jù)結(jié)構(gòu)或抽象概念。在計算機科學(xué)中,容器的概念經(jīng)常出現(xiàn)在數(shù)據(jù)結(jié)...詳情>>

2023-05-08 13:41:00