第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

在 int 數(shù)組中,如何返回對(duì)應(yīng)于最低值的索引?

在 int 數(shù)組中,如何返回對(duì)應(yīng)于最低值的索引?

汪汪一只貓 2023-08-09 16:10:12
我已經(jīng)設(shè)法用“最低”變量找到數(shù)組中的最低值,但我正在尋找與數(shù)組中最低值相對(duì)應(yīng)的索引。有任何想法嗎?public class Marathon {    public static void main(String[] args) {        String[] names = { "Elena", "Thomas", "Hamilton", "Suzie", "Phil",                            "Matt", "Alex", "Emma", "John", "James", "Jane",                           "Emily", "Daniel", "Neda", "Aaron", "Kate" };        int[] times = { 341, 273, 278, 329, 445, 402, 388, 275, 243, 334,                         412, 393, 299, 343, 317, 265 };        for (int i = 0; i < names.length; i++) {            System.out.println(names[i] + ": " + times[i]);        }        lowesttime(names, times);    }    public static void lowesttime(String names[], int times[]) {        int lowest;        lowest = times[0];        for (int i = 1; i < times.length; i++) {            if (times[i] < lowest) {                lowest = times[i];            }        }        System.out.println(lowest);        // to access arrays names[?], times[?}        // System.out.println(names[lowest] + ": " + times[lowest]);    }}
查看完整描述

3 回答

?
慕娘9325324

TA貢獻(xiàn)1783條經(jīng)驗(yàn) 獲得超4個(gè)贊

public static void lowesttime(String[] names, int[] times) {

    Pair<Integer, Integer> min = IntStream.range(0, times.length)

            .mapToObj(i -> new Pair<Integer, Integer>(i, times[i]))

            .reduce(new Pair<>(-1, Integer.MAX_VALUE), (r, p) ->

                r.getKey() == -1 || r.getValue() > p.getValue() ? p : r);


    String minName = p.getKey() == -1 ? "nobody" : names[p.getKey()];

    System.out.printf("Found minimum for %s at index %d, value %d%n",

        minName, min.getKey(), min.getValue());

}

我想使用 Stream 來展示:

  • IntStream.range(0, N)將給出 0, 1, 2, ..., N-1 的流。指數(shù)。

  • mapToObj轉(zhuǎn)換為 a Stream<Pair<Integer, Integer>>,其中對(duì)鍵是索引,對(duì)值是times[index]。

  • reduce將以初始對(duì)(-1,Integer.MAX_VALUE)作為結(jié)果開始,然后對(duì)于流中的每一對(duì)是否可以找到更好的最小值。

請(qǐng)注意,您可以只使用一對(duì)名稱和時(shí)間 ( Pair<String, Integer>);不需要索引。

這里可能過于高級(jí)和具體,但它非常具有表現(xiàn)力干凈(使用步驟而不需要局部變量)。


查看完整回答
反對(duì) 回復(fù) 2023-08-09
?
蝴蝶不菲

TA貢獻(xiàn)1810條經(jīng)驗(yàn) 獲得超4個(gè)贊

您可以將變量設(shè)置為元素的索引,而不僅僅是獲取該元素的值;


public static void lowesttime(String[] names, int[] times) {

    int lowest;

    int lowestIndex = 0;


    lowest = times[0];

    for (int i = 1; i < times.length; i++) {

        if (times[i] < lowest) {

            lowest = times[i];

            lowestIndex = i;

        }

    }

    System.out.println(lowest);

    System.out.println(lowestIndex);


    // to access arrays names[?], times[?}

    // System.out.println(names[lowest] + ": " + times[lowest]);


}


查看完整回答
反對(duì) 回復(fù) 2023-08-09
?
呼喚遠(yuǎn)方

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊

如果您已經(jīng)知道最低值,則可以使用:

java.util.Arrays.asList(theArray).indexOf(lowestValue)


查看完整回答
反對(duì) 回復(fù) 2023-08-09
  • 3 回答
  • 0 關(guān)注
  • 167 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)