找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
儲值後自動升級用戶組認識好友、聊天,分享生活趣事你準備好成為出色的版主了嗎?
催眠三上人妖siro無碼 meg按摩
dass 373河西川越にこ免裝子豚の館夏季刻まれた

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

[簡]狼與辛香料 Merch

[繁]The Grimm Variat

文化大革命 紀實錄像

[繁]無職轉生 第二季1

[繁]轉生貴族憑鑑定技

[繁]魔王學院的不適任
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 4493|回復: 4
打印上一主題下一主題

[問題]link list反轉(invert)[複製鏈接]

st474ddr 該用戶已被刪除
跳轉到指定樓層
樓主
發表於 2016-12-1 02:56 PM|只看該作者|倒序瀏覽
所有積分大於負-100的壞孩子,將可獲得重新機會成為懲罰生,權限跟幼兒生一樣。
本帖最後由 st474ddr 於 2016-12-1 02:57 PM 編輯

小弟剛開始學link list
看到一個習題是單純反轉link list
有個疑問 為什麼我不能輸入什麼就馬上輸出
這樣不是會更快嗎?
但是用online judge的系統卻沒辦法
是有什麼測資會爆炸嗎?


那我該如何從link list下手
如何讓1 2 3 4 5讀檔進去
link list 反轉後
變成5 4 3 2 1
求各位大大開導
...
瀏覽完整內容,請先 註冊登入會員

點評

scottcheng https://en.wikipedia.org/wiki/Doubly_linked_list  發表於 2016-12-2 09:30 PM
scottcheng 雙向link 就好了!  發表於 2016-12-2 09:29 PM
分享分享0收藏收藏0支持支持0
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。

使用道具檢舉

CoNsTaRwU 該用戶已被刪除
頭香
發表於 2016-12-8 04:59 AM|只看該作者
本帖最後由 CoNsTaRwU 於 2016-12-13 01:46 AM 編輯

reverse 在數學上的意義用 Agda 表達是:
  1. data ℕ : Set where
  2.   zero : ℕ
  3.   suc  : ℕ → ℕ

  4. data Vect {l} (A : Set l) : ℕ → Set l where
  5.   []  : Vect A zero
  6.   _∷_ : ∀ {n} → A → Vect A n → Vect A (suc n)

  7. insert : ∀ {l n} {A : Set l} → A → Vect A n → Vect A (suc n)
  8. insert x []       = x ∷ []
  9. insert x (y ∷ ys) = y ∷ (insert x ys)

  10. reverse : ∀ {l n} {A : Set l} → Vect A n → Vect A n
  11. reverse (x ∷ xs) = insert x (reverse xs)
  12. reverse whatever = whatever
複製代碼
用 C++ 來實作的話,SGI 版本的 stl 的 std::list 對 reverse 的實作大約是像這樣(我大約寫的,不一定完全相同):
  1. void
  2. M_reverse_() noexcept
  3. {
  4.   list_node_base_* tmp__ = this;
  5.   do
  6.     {
  7.       std::swap(tmp__->M_next_, tmp__->M_prev_);
  8.       tmp__ = tmp__->M_prev_;
  9.     }
  10.   while (tmp__ != this);
  11. }

  12. void
  13. reverse() noexcept
  14. { this->M_impl_.M_node_.M_reverse_(); }
複製代碼
...
瀏覽完整內容,請先 註冊登入會員
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

Rank: 2Rank: 2

帖子
571
積分
352 點
潛水值
3300 米
3
發表於 2017-1-16 12:52 AM|只看該作者
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php
本帖最後由 hf387 於 2017-1-16 12:56 AM 編輯

可以一開始就反著連
新的 Node 往前一個 Node 連
Head 指向新的 Node

簡單寫大概這樣吧(沒驗證)
  1. Node* mHead = NULL;

  2. Node* mNode = new Node;
  3. mNode->next = mHead;
  4. mHead = mNode;
複製代碼

使用道具檢舉

帖子
111
積分
0 點
潛水值
24790 米
4
發表於 2017-2-27 05:01 PM|只看該作者
如果發覺自己無法使用一些功能或出現問題,請按重新整理一次,並待所有網頁內容完全載入後5秒才進行操作。
hi, 你可以學學stl 裡面有很多好用的容器
自己做太累的 不然網路上也有很多範例

使用道具檢舉

o_g349 該用戶已被刪除
5
發表於 2017-9-12 11:07 PM|只看該作者
你可以用 doubly linked list 偷吃步,不過既然會考你 link list 反轉,應該是要考你如何將單向 linked list 反轉,你需要同時用三個變數紀錄前一個、後一個、和現在的節點,演算法如下:
  1. static wznode *
  2. wz_invert_node(wznode * node) { /* node must not be NULL */
  3.   wznode * root;
  4.   wznode * c = node; /* c => child */
  5.   wznode * n = c->parent; /* n => node */
  6.   wznode * p; /* p => parent */
  7.   for (;;) {
  8.     if (n == NULL) {
  9.       root = c;
  10.       break;
  11.     }
  12.     p = n->parent;
  13.     n->parent = c;
  14.     if (p == NULL) {
  15.       root = n;
  16.       break;
  17.     }
  18.     c = n;
  19.     n = p;
  20.   }
  21.   node->parent = NULL;
  22.   return root;
  23. }
複製代碼
以這個例子說明,每個 node 都有自己的父節點,利用各自的父節點將節點們連接成一個單向 linked list,最頂端的父節點的父節點是 NULL,相當於單向 linked list 的尾巴,最底端的子節點相當於單向 linked list 的頭,這個函數將最底端的子節點作為輸入,然後將整條單向 linked list 反轉後回傳原本最頂端的父節點,也就是新的單向 linked list 的頭...
瀏覽完整內容,請先 註冊登入會員





分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部