看板 MATLAB 關於我們 聯絡資訊
嗨嗨各位好 這是小弟我第一次發文 問題是這樣的 我有1 2 3 4 5 6 六個數字 希望能找出所有後一數比前一數大於或小於的排列 就像我現在想排三位的 排法就有 111 112 113 114 115 116 122 123 124 125 126 133 134 135 136 144 145 146 ....... 555 556 566 666 然後他的迴圈如下 a=0; x=[]; for i1=1:6 for i2=i1:6 for i3=i2:6 x(a)=i1*100+i2*10+i3; a=a+1; end end end 這樣就能求出我的x陣列 每個都是三位數 然後現在希望使用者可以輸入她想要的位數 像如果他輸入2的話 就會有如下迴圈的程式 a=0; x=[]; for i1=1:6 for i2=i1:6 x(a)=i1*10+i2; a=a+1; end end 如果輸入3 就會有第一個迴圈的程式 於是我就卡關了 不知道怎麼讓for迴圈數隨著輸入值變而變 (有想過用遞迴 但沒寫出來 還是說可以寫出來?) 因此請教各位大大<(_ _)> ..................................................... 不好意思 我再寫詳細一點 現在題目是 我想寫一個函數func(n) 然後如果我輸入func(1) 會出來陣列x 讓 x(0)=1 x(1)=2 x(2)=3 x(3)=4 x(4)=5 x(5)=6 如果輸入func(2) 就會出來陣列x 讓 x(0)=11 x(1)=12 x(2)=13 x(3)=14 x(4)=15 x(5)=16 x(6)=22 x(7)=23 x(8)=24 x(9)=25 x(10)=26 x(11)=33 x(12)=34 x(13)=35 x(14)=36 x(15)=44 x(16)=45 x(17)=46 x(18)=55 x(19)=56 x(20)=66 如果輸入func(3) 就會出來陣列x 讓 x(0)=111 x(1)=112 x(2)=113 x(3)=114 x(4)=115 x(5)=116 x(6)=122 x(7)=123 x(8)=124 x(9)=125 x(10)=126 x(11)=133 x(12)=134 x(13)=135 x(14)=136 x(15)=144 x(16)=145 x(17)=146 x(18)=155 x(19)=156 x(20)=166 x(21)=222 x(22)=223 x(23)=224 x(24)=225 x(25)=226 x(26)=233 x(27)=234 x(28)=235 x(29)=236 x(30)=244 x(31)=245 x(32)=246 x(33)=255 x(34)=256 x(35)=266 x(36)=333 x(37)=334 x(38)=335 x(39)=336 x(40)=344 x(41)=345 x(42)=346 x(43)=355 x(44)=356 x(45)=366 x(46)=444 x(47)=445 x(48)=446 x(49)=455 x(50)=456 x(51)=466 x(52)=555 x(53)=556 x(54)=566 x(55)=666 以此類推 然後像func(1)的程式 a=0; x=[]; for i1=1:6 x(a)=i1; a=a+1; end func(2)的程式 a=0; x=[]; for i1=1:6 for i2=i1:6 x(a)=i1*10+i2; a=a+1; end end func(3)的程式 a=0; x=[]; for i1=1:6 for i2=i1:6 for i3=i2:6 x(a)=i1*100+i2*10+i3; a=a+1; end end end n是多少 for就有多少 不過就是不會打會隨著n變 for的個數也變的程式 因此請教各位大大 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 58.114.162.15 ※ 文章網址: http://www.ptt.cc/bbs/MATLAB/M.1407600046.A.96B.html
profyang: 雖然看不太懂你後面的for loop跟你前面有啥關係 不過你 08/10 10:56
profyang: 可以考慮用for loop產生字串再用eval 08/10 10:56
profyang: 你可以先用ndgrid產生所有6^3種排列 然後再去sort再刪掉 08/10 11:13
profyang: 重複的就好了 08/10 11:13
celestialgod: x = []; m = nchoosek(1:6, 3); 08/10 16:41
celestialgod: for i = 1:size(m, 1); x = [x; perms(m(i,:))];end 08/10 16:41
celestialgod: x = x * [100; 10; 1]; 08/10 16:41
celestialgod: 不用用三個迴圈做... 08/10 16:42
celestialgod: 我也不知道你後面再說什麼... 08/10 16:42
profyang: 樓上你確定你那樣是對的? nchoosek的話不會重複喔 像112 08/10 17:16
profyang: 這種就沒有 08/10 17:16
※ 編輯: ches51311 (58.114.162.15), 08/10/2014 17:56:31
celestialgod: 喔,對耶,我真的寫錯了,抱歉。 08/10 20:44
Rasin: 可以用矩陣就別用迴圈 可以用迴圈就別用遞回 08/11 00:18