[討論] for迴圈數隨輸入的數字而變

看板MATLAB作者 (游泳迪)時間11年前 (2014/08/10 00:00), 11年前編輯推噓4(409)
留言13則, 3人參與, 最新討論串1/2 (看更多)
嗨嗨各位好 這是小弟我第一次發文 問題是這樣的 我有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

08/10 10:56, , 1F
雖然看不太懂你後面的for loop跟你前面有啥關係 不過你
08/10 10:56, 1F

08/10 10:56, , 2F
可以考慮用for loop產生字串再用eval
08/10 10:56, 2F

08/10 11:13, , 3F
你可以先用ndgrid產生所有6^3種排列 然後再去sort再刪掉
08/10 11:13, 3F

08/10 11:13, , 4F
重複的就好了
08/10 11:13, 4F

08/10 16:41, , 5F
x = []; m = nchoosek(1:6, 3);
08/10 16:41, 5F

08/10 16:41, , 6F
for i = 1:size(m, 1); x = [x; perms(m(i,:))];end
08/10 16:41, 6F

08/10 16:41, , 7F
x = x * [100; 10; 1];
08/10 16:41, 7F

08/10 16:42, , 8F
不用用三個迴圈做...
08/10 16:42, 8F

08/10 16:42, , 9F
我也不知道你後面再說什麼...
08/10 16:42, 9F

08/10 17:16, , 10F
樓上你確定你那樣是對的? nchoosek的話不會重複喔 像112
08/10 17:16, 10F

08/10 17:16, , 11F
這種就沒有
08/10 17:16, 11F
※ 編輯: ches51311 (58.114.162.15), 08/10/2014 17:56:31

08/10 20:44, , 12F
喔,對耶,我真的寫錯了,抱歉。
08/10 20:44, 12F

08/11 00:18, , 13F
可以用矩陣就別用迴圈 可以用迴圈就別用遞回
08/11 00:18, 13F
文章代碼(AID): #1JvaMkbh (MATLAB)
文章代碼(AID): #1JvaMkbh (MATLAB)