欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java構(gòu)建乘積數(shù)組的方法

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

本文實(shí)例為大家分享了Java構(gòu)建乘積數(shù)組的具體實(shí)現(xiàn)代碼,供大家參考,具體內(nèi)容如下

給定一個(gè)數(shù)組A[0,1,…,n-1],請(qǐng)構(gòu)建一個(gè)數(shù)組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;
 }

解法二

從中可以看出通過(guò)數(shù)組A計(jì)算數(shù)組B的時(shí)候,紅色部分不參與乘積的計(jì)算,以紅色部分做分割,可以看錯(cuò)是紅色左邊部分的乘積與紅色右邊部分乘積的乘積

所以此時(shí)先根據(jù)數(shù)組A把對(duì)應(yīng)左邊部分的乘積和右邊部分的乘積分別計(jì)算出來(lái)得到兩個(gè)新的數(shù)組,即LEFT和RIGHT

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

  • 對(duì)于B[0],因?yàn)闆]有左邊部分,可以認(rèn)為是1*RIGHT[0]
  • 如果B[n-1],沒有右邊部分,所以認(rèn)為是LEFT[n-1]*1

以下是代碼實(shí)現(xiàn)

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];
 // 數(shù)組B中第一個(gè)數(shù)字沒有左邊部分,所以左邊乘積數(shù)組第一個(gè)數(shù)字是1
 left[0] = 1;
 // 計(jì)算B[i]對(duì)應(yīng)的在A中的左邊部分的乘積,數(shù)組A從前向后計(jì)算
 for (int i = 1; i < len; i++) {
 // 因?yàn)橐狟[i]不需要計(jì)算A[i],所以左邊部分的乘積計(jì)算其實(shí)需要的是A中對(duì)應(yīng)下標(biāo)i的上一個(gè)下標(biāo)及之前的數(shù)字
 left[i] = left[i - 1] * array[i - 1];
 }
 // 數(shù)組B中最后一個(gè)數(shù)字沒有右邊部分,所以右邊乘積數(shù)組的最后一個(gè)數(shù)字是1
 right[len - 1] = 1;
 // 計(jì)算B[i]對(duì)應(yīng)的在A中的右邊部分的乘積,數(shù)組A從后向前計(jì)算,這樣才可以一次遍歷完
 // 因?yàn)橛?jì)算可以用到上一次的結(jié)果,即上一次的結(jié)果*本次下標(biāo)的值
 for (int i = len - 1; i > 0 ; i--) {
 // 因?yàn)橐狟[i]不需要計(jì)算A[i],所以右邊部分的乘積計(jì)算其實(shí)需要的是A中對(duì)應(yīng)下標(biāo)i的下一個(gè)下標(biāo)及之后的數(shù)字
 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 + " ");
 }

}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java基于JDBC實(shí)現(xiàn)事務(wù),銀行轉(zhuǎn)賬及貨物進(jìn)出庫(kù)功能示例

    Java基于JDBC實(shí)現(xiàn)事務(wù),銀行轉(zhuǎn)賬及貨物進(jìn)出庫(kù)功能示例

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

    java調(diào)用python腳本引入第三方庫(kù)失敗的實(shí)現(xiàn)

    本文主要介紹了java調(diào)用python腳本引入第三方庫(kù)失敗的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Java基礎(chǔ)學(xué)習(xí)筆記之?dāng)?shù)組詳解

    Java基礎(chǔ)學(xué)習(xí)筆記之?dāng)?shù)組詳解

    這篇文章主要介紹了Java基礎(chǔ)學(xué)習(xí)筆記之?dāng)?shù)組,結(jié)合實(shí)例形式詳細(xì)分析了java的基本概念、定義、迭代、輸出、反轉(zhuǎn)、排序等常用操作技巧,需要的朋友可以參考下
    2019-08-08
  • java集合類HashMap源碼解析

    java集合類HashMap源碼解析

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

    詳解JAVA設(shè)計(jì)模式之模板模式

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

    Java循環(huán)對(duì)bean的屬性進(jìn)行賦值的實(shí)現(xiàn)

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

    基于Java中字符串內(nèi)存位置詳解

    下面小編就為大家?guī)?lái)一篇基于Java中字符串內(nèi)存位置詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-08-08
  • Javaweb EL自定義函數(shù)開發(fā)及代碼實(shí)例

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

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

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

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

    Java加載properties文件實(shí)現(xiàn)方式詳解

    這篇文章主要介紹了Java加載properties文件實(shí)現(xiàn)方式詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07

最新評(píng)論