C_Sharp 板


LINE

老師給了一段單向佇列的code,要改成雙向佇列(其實也就是加上一個previous) 因為之前用C有寫過類似的作業,用一樣的邏輯寫也沒有bug 但是執行後卻一直顯示"並未將物件參考設定為物件的執行個體" 我只知道哪一段程式碼出了問題,但不知道發生了甚麼事 下面附上我的code,希望版上大大不吝指教 謝謝 using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace StackNodeTest { class Program { static void Main(string[] args) { String taken; Stack s = new Stack(); ; Console.WriteLine("Stack START:(Enter Number, '#' to End)\n-----"); do { taken = Console.ReadLine(); if (taken != "#") { s.push(int.Parse(taken)); } } while (taken != "#"); do { int e; s.pop(out e); Console.WriteLine(e); } while (s.checktop()); Console.Read(); } } class Stack { private Node Top; private Node botton; public Stack() { this.Top = null; } public bool push(int x) { Node p=new Node(x,Top); this.Top.Setprevious(p);開發環境顯示這一行有問題 if (this.Top == null) { this.Top =this.botton = p; } else { this.Top = p; } return true; } public bool pop(out int x) { x = Top.getdata(); this.Top = Top.getnext(); return true; } public bool popfrombotton(out int x) { x = botton.getdata(); this.botton = botton.getprevious(); return true; } public bool checktop() { return this.Top != null; } } class Node { private int data; private Node next; public Node previous; public Node(int x, Node next) { Setdata(x); Setnext(next); this.previous = null; } public void Setdata(int x) { this.data = x; } public void Setnext(Node next) { this.next = next; } public void Setprevious(Node previous) { this.previous = previous; } public int getdata() { return this.data; } public Node getnext() { return this.next; } public Node getprevious() { return this.previous; } } } --
1F:推 olduck:紅豆生南國12/25 16:07
2F:推 newmatt: 春來發起痴12/25 16:56
3F:推 asdfzx: 願插郭采潔12/25 17:34
4F:推 otakuwill: 恥物最香濕12/25 17:39
5F:推 a01000a:王摩詰-香濕12/25 18:10
6F:推 jpsstargazer:前幾樓淫出好詩呀12/25 20:07
--



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 49.158.2.110
7F:→ luj810714:最後我用try-catch把那一行隔離後不管exception message 03/31 03:20
8F:→ luj810714:程式一樣可以執行,但我還是希望可以了解問題發生原因@@ 03/31 03:20
9F:→ ssccg:因為this.Top一開始是null啊 03/31 04:22
10F:→ ssccg:就在那下面不就正有檢查this.Top是不是null的code? 03/31 04:22
11F:→ ssccg:那一樣使用this.Top的那行不也應該先確定是不是null? 03/31 04:26
12F:推 Eleganse:這樣寫當然可以 加個try-catch沒啥問題 能跑就是正確程序 03/31 08:05
13F:→ Eleganse:但是類別stack的建構函數stack()中 程式塞了個null給它 03/31 08:06
14F:→ Eleganse:如果成員是null 程式還能正常跑不就活見鬼了 03/31 08:07
15F:→ Eleganse:當然當你作了第1次PUSH後 裡面有值了 物件就開始正確運行 03/31 08:08
16F:→ Eleganse:因此try-catch程序ok 只在物件初始化時 進了1次catch而已 03/31 08:09
17F:→ Eleganse:不喜歡的話 那就把stack類別砍掉重練 03/31 08:11
18F:→ Eleganse:依你自已的邏輯重寫 記得建構函數時要塞值進去 不要null 03/31 08:12
19F:→ Eleganse:然後我剛才突然想到 System.Collections裡不是就有個 03/31 08:21
20F:→ Eleganse:stack類別...那幹麻自已寫啊 03/31 08:21
21F:→ luj810714:感謝!原來如此!!,但依我設計的邏輯是,當他POP時發現 03/31 21:18
22F:→ luj810714:Top是null時就跳出do-while迴圈,那麼是否有其他替代方 03/31 21:19
23F:→ luj810714:案呢? 03/31 21:19
24F:→ ssccg:跟pop有什麼關係? 問題那行在push裡面啊 04/01 00:41
25F:→ ssccg:把那行移到else裡面,this.Top = p; 上面就好了 04/01 00:41
26F:→ ssccg:這明明是流程設計上有問題,因此加try-catch一點都不ok 04/01 00:42







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Soft_Job站內搜尋

TOP