亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何檢查一個數組是否具有另一個數組的平方元素(無論順序如何)?

如何檢查一個數組是否具有另一個數組的平方元素(無論順序如何)?

尚方寶劍之說 2023-06-21 15:34:17
a = [121, 144, 19, 161, 19, 144, 19, 11]b = [121, 14641, 20736, 361, 25921, 361, 20736, 361] 返回 true,因為 b[] 具有元素的平方值在 a[] 中,無論順序如何。這是我嘗試過的...static boolean comp(int a[], int b[]) {        int x = 0;        if (a.equals(b)) {            for (int i : a) {                for (int j : b) {                    if (a[i] == b[j] * b[j]) {                        x++;                    } else {                        x--;                    }                }            }        } else {            return false;        }        if (x == a.length) {            return true;        } else {            return false;        }    }
查看完整描述

6 回答

?
幕布斯7119047

TA貢獻1794條經驗 獲得超8個贊

這很簡單:


static boolean comp(int a[], int b[]) {


    for (int i : a) {

        if (!Arrays.asList(b).contains(i*i)) {

            return false;

        }

    }

    return true;

}

簡而言之,你遍歷 a 和 b 的每個值,看看 a 的平方值是否是 b。當你發現不匹配時,你會自動返回 false。否則,返回 true。


查看完整回答
反對 回復 2023-06-21
?
狐的傳說

TA貢獻1804條經驗 獲得超3個贊

public static Boolean compare(int[] a, int[] b) {

  Arrays.sort(a);

  Arrays.sort(b);

  for (int i = 0; i < a.length; i++) {

    if (a[i] * a[i] != b[i]) {

      return false;

    }

  }

  return true;

}


查看完整回答
反對 回復 2023-06-21
?
holdtom

TA貢獻1805條經驗 獲得超10個贊

static boolean comp(int a[], int b[]) {


    for (int i : a) {

        if (!Arrays.asList(b).contains(i*i)) {

            return false;

        }

    }

    return true;

}


查看完整回答
反對 回復 2023-06-21
?
慕斯王

TA貢獻1864條經驗 獲得超2個贊

List有一個containsAll,我會用它;使用 Java 8+ 和流可能看起來像


static boolean comp(int a[], int b[]) {

? ? return Arrays.stream(b).distinct().boxed().collect(Collectors.toList())

? ? ? ? ? ? .containsAll(Arrays.stream(a).map(x -> x * x).boxed()

? ? ? ? ? ? .collect(Collectors.toList()));

}


查看完整回答
反對 回復 2023-06-21
?
繁花不似錦

TA貢獻1851條經驗 獲得超4個贊

bool Same(int[] arr1, int[] arr2)

{

    for (int i = 0; i < arr1.Length; i++)

    {

        var correctIndex = Array.IndexOf(arr2, (int)Math.Pow(arr1[i], 2));

        if (correctIndex == -1)

        {

            return false;

        }

        arr2.Take(correctIndex);

    }

    return true;

}


in c#


查看完整回答
反對 回復 2023-06-21
?
婷婷同學_

TA貢獻1844條經驗 獲得超8個贊

public static Boolean compare(int[] a, int[] b) {

  Arrays.sort(a);

  Arrays.sort(b);

  for (int i = 0; i < a.length; i++) {

    if (a[i] * a[i] != b[i]) {

      return false;

    }

  }

  return true;

}


查看完整回答
反對 回復 2023-06-21
  • 6 回答
  • 0 關注
  • 237 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號