亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java構建乘積數組的方法

 更新時間:2019年03月04日 08:26:43   作者:雨幕下的稻田  
這篇文章主要為大家詳細介紹了Java構建乘積數組的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Java構建乘積數組的具體實現代碼,供大家參考,具體內容如下

給定一個數組A[0,1,…,n-1],請構建一個數組B[0,1,…,n-1],其中B中的元素B[i]=A[0]A[1]…A[i-1]*A[i+1]…*A[n-1]。

不能使用除法。

代碼

解法一

暴力法,這是本能就能想到的解決辦法。

public static int[] multiply(int[] array) {
 if (array == null) {
 return null;
 }
 int len = array.length;
 if (len == 0) {
 return null;
 }
 int[] result = new int[len];
 for (int i = 0; i < len; i++) {
 int multiply = 1;
 for (int j = 0; j < len; j++) {
  if (j != i) {
  multiply *= array[j];
  }
 }
 result[i] = multiply;
 }
 return result;
 }

解法二

從中可以看出通過數組A計算數組B的時候,紅色部分不參與乘積的計算,以紅色部分做分割,可以看錯是紅色左邊部分的乘積與紅色右邊部分乘積的乘積

所以此時先根據數組A把對應左邊部分的乘積和右邊部分的乘積分別計算出來得到兩個新的數組,即LEFT和RIGHT

這樣可以得到公式:B[i]=LEFT[i]*RIGHT[i],如下所示

  • 對于B[0],因為沒有左邊部分,可以認為是1*RIGHT[0]
  • 如果B[n-1],沒有右邊部分,所以認為是LEFT[n-1]*1

以下是代碼實現

public static int[] multiply2(int[] array) {
 if (array == null) {
 return null;
 }
 int len = array.length;
 if (len == 0) {
 return null;
 }
 int[] left = new int[len];
 int[] right = new int[len];
 int[] result = new int[len];
 // 數組B中第一個數字沒有左邊部分,所以左邊乘積數組第一個數字是1
 left[0] = 1;
 // 計算B[i]對應的在A中的左邊部分的乘積,數組A從前向后計算
 for (int i = 1; i < len; i++) {
 // 因為要B[i]不需要計算A[i],所以左邊部分的乘積計算其實需要的是A中對應下標i的上一個下標及之前的數字
 left[i] = left[i - 1] * array[i - 1];
 }
 // 數組B中最后一個數字沒有右邊部分,所以右邊乘積數組的最后一個數字是1
 right[len - 1] = 1;
 // 計算B[i]對應的在A中的右邊部分的乘積,數組A從后向前計算,這樣才可以一次遍歷完
 // 因為計算可以用到上一次的結果,即上一次的結果*本次下標的值
 for (int i = len - 1; i > 0 ; i--) {
 // 因為要B[i]不需要計算A[i],所以右邊部分的乘積計算其實需要的是A中對應下標i的下一個下標及之后的數字
 right[i - 1] = right[i] * array[i];
 }
 for (int i = 0; i < len; i++) {
 result[i] = left[i] * right[i];
 }
 return result;
 }
 
 
 public static void main(String[] args) {
 int[] array = {1, 2, 3, 4};
 int[] result = multiply2(array);
 for (Integer i : result) {
 System.out.print(i + " ");
 }

}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Java基于JDBC實現事務,銀行轉賬及貨物進出庫功能示例

    Java基于JDBC實現事務,銀行轉賬及貨物進出庫功能示例

    這篇文章主要介紹了Java基于JDBC實現事務,銀行轉賬及貨物進出庫功能,較為詳細的分析了事務操作的原理、實現方法及java基于jdbc連接數據庫實現銀行事務操作的相關技巧,需要的朋友可以參考下
    2017-12-12
  • java調用python腳本引入第三方庫失敗的實現

    java調用python腳本引入第三方庫失敗的實現

    本文主要介紹了java調用python腳本引入第三方庫失敗的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • Java基礎學習筆記之數組詳解

    Java基礎學習筆記之數組詳解

    這篇文章主要介紹了Java基礎學習筆記之數組,結合實例形式詳細分析了java的基本概念、定義、迭代、輸出、反轉、排序等常用操作技巧,需要的朋友可以參考下
    2019-08-08
  • java集合類HashMap源碼解析

    java集合類HashMap源碼解析

    這篇文章主要介紹了Java集合之HashMap用法,結合實例形式分析了java map集合中HashMap定義、遍歷等相關操作技巧,需要的朋友可以參考下
    2021-06-06
  • 詳解JAVA設計模式之模板模式

    詳解JAVA設計模式之模板模式

    這篇文章主要介紹了詳解JAVA設計模式之模板模式的的相關資料,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-06-06
  • Java循環(huán)對bean的屬性進行賦值的實現

    Java循環(huán)對bean的屬性進行賦值的實現

    本文主要介紹了Java循環(huán)對bean的屬性進行賦值,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 基于Java中字符串內存位置詳解

    基于Java中字符串內存位置詳解

    下面小編就為大家?guī)硪黄贘ava中字符串內存位置詳解。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • Javaweb EL自定義函數開發(fā)及代碼實例

    Javaweb EL自定義函數開發(fā)及代碼實例

    這篇文章主要介紹了Javaweb EL自定義函數開發(fā)及代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • Java自然排序Comparable使用方法解析

    Java自然排序Comparable使用方法解析

    這篇文章主要介紹了Java自然排序Comparable使用方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • Java加載properties文件實現方式詳解

    Java加載properties文件實現方式詳解

    這篇文章主要介紹了Java加載properties文件實現方式詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07

最新評論