PTT
Submit
Submit
選擇語言
正體中文
简体中文
PTT
java
[問題] array 長度
作者:
kasey
( )
2017-07-17 14:07:21
大家好,我初學Java沒多久,最近遇到一個問題。假設有一個 array 裡面的數字不重複
,任意給定一個數字,在不用迴圈的情形下要怎麼算此 array 的長度呢?我目前是想到
用 recursion ,可是我寫的結果都沒有成功 orz,麻煩各位大大解惑
用迴圈的程式如下:
int length(int [] s, int x)
int l;
int y = x;
while (true) {
if (s[x] == y) {
return l;
}
x = s[x];
++l;
}
}
作者:
ssccg
(23)
2017-07-17 14:13:00
array.length?你要算的長度到底是什麼東西
作者:
kasey
( )
2017-07-17 14:17:00
就是array.length 但是不能用array.length()也不能用迴圈...
作者:
ssccg
(23)
2017-07-17 14:25:00
array的長度跟array的內容有關係? 你這是解題目的話至少完整描述題目吧... 不然為什麼不用array.length
作者:
s06i06
(三條魚)
2017-07-17 14:29:00
沒看懂題目在說什麼 算長度參數傳一個x幹嘛
作者:
kasey
( )
2017-07-17 14:32:00
測試用的 array s 裡的元素是不重複的數字。如果長度是6,則數字是0~5任意排列。
作者:
ssccg
(23)
2017-07-17 14:39:00
所以要求的是array內容的最大值? 另外你說不能用迴圈那你的while是?
作者:
kasey
( )
2017-07-17 14:43:00
要求的是 array 的長度,int x 是一開始先丟一個任意0~5的數字進去。while 是題目給的示範,但是有另外要求不能用迴圈寫但是函式還是 int length(int [] s, int x),只是內容不能用迴圈
作者:
ssccg
(23)
2017-07-17 14:51:00
我覺得題目看起來是求存在array裡的circular linked list長度,不是array的長度,x代表的是這個list的head pointer
作者:
kasey
( )
2017-07-17 15:07:00
唔... 這麼一說感覺有點像。那如果從他給的示範改成遞迴的形式,該怎麼改好呢?
作者:
ssccg
(23)
2017-07-17 15:56:00
int len(int[] s, int x, int y) {return s[x] == y ? 1 : 1 + len(s, s[x], y); }length內容為 return len(s, x, x)要跟你的版本一樣的話條件成立時要return 0,不過我覺得 1的結果才合理,這題目head不會是null所以至少一個node
作者:
kasey
( )
2017-07-18 01:28:00
謝謝。可是有辦法用 int len(int[] s, int x) 寫嗎?我目前依他的條件找不到好方法存第一個 x 去比較
作者: Schaos
2017-07-18 02:01:00
你可以在遞迴前留一份啊,題目沒限制變數數量。
作者:
kasey
( )
2017-07-18 02:14:00
變數只能寫在length()裡,可是都會被update... 不太曉得該怎麼留
作者:
ssccg
(23)
2017-07-18 10:15:00
一定需要的東西想辦法塞進參數裡,需要記下來的放在localvariable其實題目 ONLY AFTER ... 那句是很大的提示了
繼續閱讀
[問題] 找出陣列的最小公倍數
lumixfilm
[問題] Vector迴圈填值的問題
conlich
[問題] package exploer 要怎麼開啟?
yee232yee
[問題] 如何解決javaw CPU使用率100%的問題
eva19452002
[問題] 關於x&y的運作
wsx247
Re: [網站] 資料結構練習系統開放試用
infomandyu
[網站] 資料結構練習系統開放試用
infomandyu
[JSP ] filter實作後沒辦法正常到其他網頁
zelkova
[問題] SecureRandom的原理是什麼?
sky800507
[問題] Tomcat 外部連線問題
jeep168917
Links
booklink
Contact Us: admin [ a t ] ucptt.com