zoukankan      html  css  js  c++  java
  • 【IT笔试面试题整理】给定一个数组a[N]构造数组b [N]

    [来源]:腾讯2013实习生笔试  

      给定一个数组a[N],我们希望构造数组b [N],其中b[j]=a[0]*a[1]…a[N-1] / a[j],在构造过程中,不允许使用除法:要求O1)空间复杂度和On)的时间复杂度;除遍历计数器与a[N] b[N]外,不可使用新的变量(包括栈临时变量、堆空间和全局静态变量等)

    解析:b[0]=1

    b[i]=b[i-1]*a[i-1]可得

    b[1] = a[0]

    b[2] = a[0]a[1]

    b[i] = a[0]a[1]a[2]…a[i-1]

    b[n-1] = a[0]a[1]…a[n-2]

    那么再通过b[0]这个变量来迭代出1, a[n-1], a[n-2]a[n-1], a[n-3]a[n-2]a[n-1], … , a[1]a[2]a[3]…a[n-1],迭代过程中分别乘以b[n-1], b[n-2], … , b[0]

    代码如下:

     1     // 第一轮循环用作计算 b[i] = a[0]*a[2]*...*a[i-1]
     2     // 即 a[i]左边的累乘...
     3     //
     4     // 第二轮则,b[0]则是从右边累乘起来的,相当于右半边的部分
     5     // a[i+1]*a[i+2]...*a[N-1]
     6     // 然后即是b[i] *= b[0]....得出结果
     7     public static void generateArray(int[] a, int b[])
     8     {
     9         b[0] = 1;
    10         for (int i = 1; i < a.length; i++)
    11         {
    12             b[i] = b[i - 1] * a[i - 1];
    13         }
    14         System.out.println();
    15 
    16         for (int i = a.length - 1; i >= 1; i--)
    17         {
    18             b[i] *= b[0];
    19             b[0] *= a[i];
    20         }
    21     }
  • 相关阅读:
    pytorch获取模型某一层参数名及参数值方式
    PyTorch源码解读之torchvision.models
    torch.nn.Conv2d()函数详解
    UCF101
    ipynb格式转换
    linux下的压缩与解压缩
    tomcat 部署的项目图片名字带中文
    恢复oracle误删除数据
    项目中遇到的分布式高并发情况及解决方案
    poi 导出复杂表头 execl
  • 原文地址:https://www.cnblogs.com/WayneZeng/p/9290747.html
Copyright © 2011-2022 走看看