チェーン時計の経典の筆記試験問題
9956 ワード
1.2つの順序付きチェーンテーブルを新しい順序付きチェーンテーブルに結合して戻します.新しいチェーンテーブルは、指定された2つのチェーンテーブルのすべてのノードを接合することによって構成されます.
2.与えられた値xを基準としてチェーンテーブルを2つの部分に分割するコードを作成し、x未満のすべてのノードがx以上のノードの前に並ぶ
チェーンテーブルのヘッダポインタListNode*pHeadを指定し、並べ替えたチェーンテーブルのヘッダポインタを返します.注意:分割後も元のデータの順序は変わらない.
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
if(l1 == null){
//l1 , l2
return l2;
}
if(l2 == null){
//l2 , l2
return l1;
}
ListNode newHead = new ListNode(-1);//
ListNode newTail = newHead;
ListNode cur1 = l1;
ListNode cur2 = l2;
while(cur1 != null &&cur2 != null){
if(cur1.val < cur2.val){
// cur1
// ,newTail null null
newTail.next = cur1;
newTail = newTail.next;
cur1 = cur1.next;
}else{
newTail.next = cur2;
newTail = newTail.next;
cur2 = cur2.next;
}
}
// , cur1 cur2
//
if(cur1 == null){
newTail.next = cur2;
}else{
newTail.next = cur1;
}
return newHead.next;
}
2.与えられた値xを基準としてチェーンテーブルを2つの部分に分割するコードを作成し、x未満のすべてのノードがx以上のノードの前に並ぶ
チェーンテーブルのヘッダポインタListNode*pHeadを指定し、並べ替えたチェーンテーブルのヘッダポインタを返します.注意:分割後も元のデータの順序は変わらない.
public ListNode partition(ListNode pHead, int x) {
if(pHead == null){
return null;
}
if(pHead.next == null){
return pHead;
}
ListNode bigHead = new ListNode(-1);
ListNode bigTail = bigHead;
ListNode smallHead = new ListNode(-1);
ListNode smallTail = smallHead;
for(ListNode cur = pHead;cur != null;cur = cur.next){
if(cur.val < x){
// smallTail , ( next null)
smallTail.next = new ListNode(cur.val);
smallTail = smallTail.next;
}else{
// bigTail
bigTail.next = new ListNode(cur.val);
bigTail = bigTail.next;
}
}
//
smallTail.next = bigHead.next;
return smallHead.next;
}