一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java構建乘積數組的方法

Java構建乘積數組的方法

2021-07-18 15:44雨幕下的稻田 Java教程

這篇文章主要為大家詳細介紹了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]。

不能使用除法。

代碼

解法一

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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;
 }

解法二

Java構建乘積數組的方法

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

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

這樣可以得到公式:b[i]=left[i]*right[i],如下所示

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

Java構建乘積數組的方法

以下是代碼實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
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 + " ");
 }
 
}

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

原文鏈接:https://blog.csdn.net/zl18310999566/article/details/80271566

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 性绞姿始动作动态图 | japonensis中国东北老人 | 5g影院天天爽爽 | 成人性色生活片免费网 | 性生大片免费看 | 肉宠文很肉到处做1v1 | 国产精品久久久久久久久齐齐 | 美女毛片老太婆bbb80岁 | 99国产成人精品2021 | 苍井空av| 日韩高清无砖砖区2022 | 国内精品久久久久影院网站 | 青青在线视频观看 | 亚洲国产一区 | 性派对videofreeparty | 乌克兰一级毛片9一18 | 四虎影视免费 | 9999视频 | 草莓视频网站18勿进 | 扒开大腿狠狠挺进视频 | 99午夜| 亚洲高清国产拍精品动图 | 末发育xxxxx仙踪林 | 性做久久久久免费观看 | 亚洲人成综合在线播放 | 欧美一区二区三区精品 | 国产美女屁股直流白浆视频无遮挡 | 亚洲精品青青草原avav久久qv | 欧美日韩亚洲综合久久久 | 天天夜夜啦啦啦 | 嫩草成人影院 | 动漫精品一区二区三区3d | 国产一区二区播放 | 欧美日韩一区二区三区免费 | 全黄h全肉细节修仙玄幻文 全彩调教侵犯h本子全彩妖气he | 欧美男女交配 | 国内精品视频一区二区三区 | 欧美性理论片在线观看片免费 | 国产精品微拍 | 亚洲 欧美 国产 综合首页 | 国产精品制服丝袜白丝www |