首页 > 其他 > 详细

Multiplication of numbers

时间:2014-05-23 23:46:41      阅读:536      评论:0      收藏:0      [点我收藏+]

Questin:

There is an array A[N] of N numbers. You have to compose an array Output[N] such that Output[i] will be equal to multiplication of all the elements of A[N] except A[i]. Solve it without division operator and in O(n).

For example Output[0] will be multiplication of A[1] to A[N-1] and Output[1] will be multiplication of A[0] and from A[2] to A[N-1].

Example:

A: {4, 3, 2, 1, 2}
OUTPUT: {12, 16, 24, 48, 24}

思路:

可以使用迭代累计。output[i]=a[i]左边的乘积 x a[i]右边的乘积,所以,我们可以分两个循环,第一次先把A[i]左边的乘积放在Output[i]中,第二次把A[i]右边的乘积算出来;也可以直接放在一个循环中,只不过需要同时计算左边的乘积和右边的乘积。

代码如下:

bubuko.com,布布扣
void Multiplication_Array(int A[], int OUTPUT[], int n) {
  int left = 1;
  int right = 1;
  for (int i = 0; i < n; i++)
      OUTPUT[i] = 1;
  for (int i = 0; i < n; i++) {
      OUTPUT[i] *= left;
      OUTPUT[n - 1 - i] *= right;
      left *= A[i];
      right *= A[n - 1 - i];
  }
}
bubuko.com,布布扣

Multiplication of numbers,布布扣,bubuko.com

Multiplication of numbers

原文:http://www.cnblogs.com/ywl925/p/3737008.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!