作者ches51311 (游泳迪)
看板MATLAB
標題[討論] for迴圈數隨輸入的數字而變
時間Sun Aug 10 00:00:43 2014
嗨嗨各位好 這是小弟我第一次發文
問題是這樣的 我有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