国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本午夜精品 | 欧美一区二区最爽乱淫视频免费看 | 国产精彩视频 | 欧美日韩国产一区二区三区 | 精品国产乱码久久久久久久软件 | 激情综合在线观看 | 久久天天| 色呦呦网站在线观看 | 欧美一级欧美三级在线观看 | 成人网免费看 | 国产亚洲精品久久久久久无几年桃 | 中文字幕在线三区 | 成人网av| 中文字幕免费视频 | 三级网站在线播放 | 九一视频在线观看 | 国产一区中文字幕 | 成人福利电影在线观看 | 艹久久| 精品国产欧美一区二区三区成人 | 欧美日韩精品免费 | 日日躁夜夜躁狠狠躁 | 久久在线视频 | 国产99一区二区 | 午夜视频在线 | 国产成人精品一区二区三区视频 | 人人射 | 99re在线播放视频 | 综合久久综合久久 | 午夜天堂精品久久久久 | 欧美一区二区小视频 | 天天干夜夜弄 | 免费在线黄色片 | 色啪网站 | 久久久久国产 | 亚洲精品国精品久久99热 | 99久久视频 | 国产精品日韩欧美一区二区三区 | 亚洲视频中文字幕 | 九九国产| 日韩免费高清视频 |