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

伊莉討論區

搜索
感激所有對伊莉作出奉獻的人搞笑、娛樂、精彩的影片讓你看你準備好成為出色的版主了嗎?
juliamega 無波多野結幼女惡靈古堡按摩流出
仙逆陶晶瑩紅藥丸temptati嬌寵aldn 303hoshimac

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

[繁]轉生貴族憑鑑定技

[繁]無職轉生 第二季1

(4月新番)[繁]為美好

(4月新番)[簡]怪異與

[超清繁中]霹靂英雄戰

(4月新番)[繁]狼與辛
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 1151|回復: 5
打印上一主題下一主題

[作業]C++ 關於遞回法recursive和疊代法iterative[複製鏈接]

Rank: 1

帖子
190
積分
119 點
潛水值
6570 米
跳轉到指定樓層
樓主
發表於 2013-10-14 04:44 AM|只看該作者|倒序瀏覽
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。
本帖最後由 ghost12000 於 2013-10-14 04:51 AM 編輯

想請問各位大大
我的功課是要寫出兩個不同的函式遞回recursive和疊代iterative
檢查一個陣列裡面有多少個相同的數字 ex.a[]={1,2,3,3} 3有兩次
我試著寫了遞回但是在return的部分不知道為什麼
程式最後出來的count值都是0
想請問我有哪個地方觀念錯誤還有疊代法我不是很懂要怎麼寫 跟遞回的差別在哪裡
...
瀏覽完整內容,請先 註冊登入會員
分享分享0收藏收藏0支持支持0
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

Rank: 1

帖子
190
積分
119 點
潛水值
6570 米
頭香
發表於 2013-10-14 04:49 AM|只看該作者
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。
還有不好意思~第一次發帖~剛剛爬了版規才發現要把問題改成作業~可是改不了~希望大大原諒~
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

皇臾 該用戶已被刪除
3
發表於 2013-10-14 08:36 AM|只看該作者
因為遞迴的目的是要拿原來記憶體中的變數重複計算,所以在 OCCURS 裡的 count 應該是要以 by reference方式來傳址,這樣最後才會取到經過計算的同一個記憶體位址的值,也就是說:
OCCURS 的 count 應該加上一個&,即 &count
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。

使用道具檢舉

極地之星光 該用戶已被刪除
4
發表於 2013-10-14 08:50 AM|只看該作者
本帖最後由 極地之星光 於 2013-10-14 08:51 AM 編輯

10行改為
  1. return OCCURS(x,a,n,count);
複製代碼
28行改為
  1. count = OCCURS(x,a,n-1,0);
複製代碼
直接傳入 count 函式內並不會改到值,請善用 return (10行),並存入變數中(28行)
如果不想用 return 又是另一個寫法了
另外還有一個隱藏 bug 可以自己試著去發現...
瀏覽完整內容,請先 註冊登入會員
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。

使用道具檢舉

Rank: 1

帖子
190
積分
119 點
潛水值
6570 米
5
發表於 2013-10-14 04:18 PM|只看該作者
若對尊貴或贊助會員有任何疑問,歡迎向我們查詢。我們的即時通或MSN: admin@eyny.com
感謝兩位大大的幫忙
我弄懂了這題




若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。

使用道具檢舉

dh3014 該用戶已被刪除
6
發表於 2013-10-14 11:02 PM|只看該作者
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。
樓主原先的程式味道怪怪的,讓我慢慢解釋,先看遞迴版本。
  1. int occurs (int x, int a[], int n) {
  2.   if (n < 0) return 0;
  3.   if (a[n] == x)
  4.     return occurs (x, a, n-1) + 1;
  5.   return occurs (x, a, n-1);
  6. }
複製代碼
注意到這種類型的遞迴在函式的最後,這種遞迴可以很輕鬆的改寫成迴圈型式而不需要自行建立類似堆疊的機制:
  1. int occurs (int x, int a[], int n) {
  2.   int count = 0;
  3.   while (n >= 0) {
  4.     if (a[n] == x)
  5.       count++;
  6.     n--;
  7.   }
  8.   return count;
  9. }
複製代碼
為啥會說怪怪的呢?像count++ n=n-1這種在函式內改動值的作法卻寫在遞迴版本,比較不像是一般程式員的作法,所以說「味道怪怪」,或說bad smell...
瀏覽完整內容,請先 註冊登入會員

使用道具檢舉

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

Powered by Discuz!

© Comsenz Inc.

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