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

伊莉討論區

搜索
發表文章前請先閱讀相關版規尊貴會員無限觀看附件圖片搞笑、娛樂、精彩的影片讓你看
mega無碼無碼三上強姦名偵探柯按摩
bbss 071風流書呆3124583darknessrpg 安卓bbss 063cand

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

[繁]怪人的沙拉碗07-

[簡]單人房、日照一般

[簡]被稱為廢物的原英

[繁]老夫老妻重返青春

[繁]轉生為第七王子,

[繁]迷宮飯17-
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 1570|回復: 7
打印上一主題下一主題

[問題]所有排列問題[複製鏈接]

10731leon 該用戶已被刪除
跳轉到指定樓層
樓主
發表於 2015-7-24 12:54 AM|只看該作者|倒序瀏覽
如果瀏覽伊莉時速度太慢或無法連接,可以使用其他分流瀏覽伊莉,www01.eyny.com(02,03)。

想解決的問題大概如下:
(1)找出一組數字(EX.123)的所有排列
(2)將每種可能排列儲存

我是用遞回來找所有排列,如下


#include <stdio.h>
#include <stdlib.h>
void permutation(int data[], int at, int arraySize);
int main() {
    int data[10] ;
    int MAX;
    int i;
            print f("輸入數字個數:");
...
瀏覽完整內容,請先 註冊登入會員
分享分享0收藏收藏0支持支持0
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。

使用道具檢舉

  尊貴會員

Melty Snow  雪靈

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
3224
積分
24366 點
潛水值
77410 米
頭香
發表於 2015-7-24 01:11 AM|只看該作者
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。
本帖最後由 snowflying 於 2015-7-24 02:16 PM 編輯

所有排列的話,C++ <algorithm> 的標頭檔底下
有 next_permutation 可以用
可以去研究一下用法
如果要自己實作的話,也有相關範例
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

這基本上是離散數學會教到的東西
...
瀏覽完整內容,請先 註冊登入會員
Melty Snow [雪靈]
如果發覺自己無法使用一些功能或出現問題,請按重新整理一次,並待所有網頁內容完全載入後5秒才進行操作。

使用道具檢舉

bkmambaaaa 該用戶已被刪除
3
發表於 2015-7-24 06:04 PM|只看該作者
如果瀏覽伊莉時速度太慢或無法連接,可以使用其他分流瀏覽伊莉,www01.eyny.com(02,03)。
如果是修改你的程式碼,大概加個幾行就可以,首先是要把每次排列儲存下來,你需要有對應大小的儲存空間或結構,例如一個單純的二維陣列。再來是要把每次排列儲存在某結構中,你需要記得現在存到「第幾次」排列,所以你也需要一個整數計數器。

程式碼在此(eyny也是反應內文包含敏感字串,所以放在codepad):
http://codepad.org/v2ZA418z

新增的是 3, 6, 7, 20~28, 以及 29 行。12 行多加了個整數變數 j。
...
瀏覽完整內容,請先 註冊登入會員
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。

使用道具檢舉

10731leon 該用戶已被刪除
4
發表於 2015-7-24 08:49 PM|只看該作者
bkmambaaaa 發表於 2015-7-24 06:04 PM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

如果是修改你的程式碼,大概加個幾行就可以,首先是要把每次排列儲存下來,你需要有對應大小的儲存空間或結 ...

太感謝了,我主要的困擾就是因為是遞迴式所以不知道怎麼找出「第幾次」排列,
...
瀏覽完整內容,請先 註冊登入會員

使用道具檢舉

Rank: 2Rank: 2

帖子
274
積分
373 點
潛水值
8890 米
5
發表於 2015-7-25 10:06 AM|只看該作者
10731leon 發表於 2015-7-24 08:49 PM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

太感謝了,我主要的困擾就是因為是遞迴式所以不知道怎麼找出「第幾次」排列,
感謝感謝,原來能用計數器這個 ...

拿你的例子做了點修改,供你參考,為了簡單起見,permutationResult 直接取全域的陣列,沒用 malloc 產生
...
瀏覽完整內容,請先 註冊登入會員





點評

snowflying 可以用 #define print printf 接著就能用 print 了,不必用 print f,起碼前者複製後能正常編譯 XD  發表於 2015-7-26 01:26 AM
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。

使用道具檢舉

Rank: 2Rank: 2

帖子
274
積分
373 點
潛水值
8890 米
6
發表於 2015-7-26 10:57 PM|只看該作者
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。
回 snowflying 大,我會選擇少個左括號 "(",或者像這次這樣打成 print f,
我不會選擇「#define print printf」,因為不會每個看 code 的人都明白加這行的用意,
可能有人是從寫 code 的角度看這行,此時,這行會顯得有點多餘,
或讓人不清楚為何要特別替 printf 定義一個叫 print 的別名。

點評

snowflying 空一格或少一個括號不會比較好,有些人可能會覺得編譯都不會過,這份 code 不可靠,define 後在附近加個註解就行了  發表於 2015-7-26 11:51 PM
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。

使用道具檢舉

Rank: 2Rank: 2

帖子
274
積分
373 點
潛水值
8890 米
7
發表於 2015-7-27 09:30 PM|只看該作者
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。
回 snowflying 大,個人還是偏好自己目前的做法,
我沒有想過您說的問題,也不會去考慮這問題,
個人認為 printf 造成的編譯錯誤容易被處理,
也覺得 printf 的問題對大多數發問的人來說都知道它的存在,
在編譯時自然地就會去修正它。

另外,網路上的東西本來就是給參考用的,
之前看過版上的一些帖子,裡面版友給的答案有時會對錯交雜,
...
瀏覽完整內容,請先 註冊登入會員

使用道具檢舉

Rank: 2Rank: 2

帖子
120
積分
200 點
潛水值
13918 米
8
發表於 2015-7-30 02:11 PM|只看該作者
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。
開個檔案, 將每次產生的數字排列寫入檔案內, 就可以儲存所有的排列, 也不必擔心用二維陣列儲存會有記憶體不夠用的問題.

使用道具檢舉

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

Powered by Discuz!

© Comsenz Inc.

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