線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1234
推到 Plurk!
推到 Facebook!

如何找出minvalue的index值

答題得分者是:harpist
kobebryant81
一般會員


發表:15
回覆:15
積分:6
註冊:2007-05-08

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-07-19 20:43:25 IP:163.28.xxx.xxx 訂閱
請問各位,我今天有一個10000多筆資料的陣列,那我每隔200筆要找出最小值
所以我用minvalue去找最小值,但我要知道這個最小值是發生在第幾筆資料,所以我需要知道他的index
請問要怎麼得知呢?還是說得知最小值後用迴圈去原始陣列找出跟他值相同的這種土法煉鋼法呢?謝謝指教
harpist
資深會員


發表:3
回覆:251
積分:430
註冊:2002-10-03

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-07-20 01:02:23 IP:211.74.xxx.xxx 未訂閱
使用泛型演算法加上陣列空間連續的特性這樣效率比較快
<textarea class="cpp" rows="10" cols="60" name="code">#include int main() { int Array[10] = {9,8,7,6,5,0,1,2,3,4}; int *MinValue = std::min_element(&Array[0],&Array[10]);//注意範圍指定至Array[10]但並不包括 int ValueIndex = MinValue-&Array[0]; //ValueIndex = 5 } </textarea>
------
~§~迷時師渡,悟了自渡~§~
編輯記錄
harpist 重新編輯於 2007-07-20 07:51:48, 註解 無‧
kobebryant81
一般會員


發表:15
回覆:15
積分:6
註冊:2007-05-08

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-07-20 10:41:46 IP:163.28.xxx.xxx 訂閱
To harpist,先感謝你的回答,但我有一些疑問想請教一下
我用help查了algorithm,裡面好像有很多涵式可以使用
min_element也是這涵式之一,
泛型演算法是指說min_element這個涵式嗎??,不太懂這個演算法的意思@@

第二是想請問std::的問題,查了一篇文章,為什麼要加std::
是不是指原本BCB內建宣告一個
namespace std
{
min_element()
}

所以我要使用min_element時,就得打std::min_element()這樣??

第三個問題是,既然加了std::,是不是表示有涵式名稱跟他相衝突呢??
harpist
資深會員


發表:3
回覆:251
積分:430
註冊:2002-10-03

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-07-20 13:11:30 IP:211.74.xxx.xxx 未訂閱
我也只能大概的描述一下,剩餘的就必須您自己功夫囉^_^

1.我所提的泛型演算法指的是C Standard Libary 所提供實作的泛型演算法,
min_element 函式是其中之ㄧ,用法看一下Help或書也可以拜 google 大神應該都有。
2.Namespace 是為了解決所謂 global namespace pollution (全域命名空間污染) 問題,
避免各個 Library 名稱衝突,而std 是Standard Libary 的 namespace。使用方法的資訊
也很容易取得。
3.如上。
------
~§~迷時師渡,悟了自渡~§~
kobebryant81
一般會員


發表:15
回覆:15
積分:6
註冊:2007-05-08

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-07-20 13:52:06 IP:163.28.xxx.xxx 訂閱
感謝^^
系統時間:2024-05-02 7:56:16
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!