0810------笔试题----------腾讯2012年的一道笔试题

1.题目要求

  a)b[i] = a[0] *a[1] *a[2]*….a[n-1]/ a[i],求出数组b;

  b)要求不能用除法,除循环控制变量以外,不许额外申请其余变量,时间复杂度为O(n),空间复杂度为O(1)。 

2.程序思路

  a)假设 N = 5,那么 b[0] =      a[1]*a[2]*a[3]*a[4];

                  b[1] = a[0]*     a[2]*a[3]*a[4];      

                  b[2] = a[0]*a[1]*     a[3]*a[4];

                    b[3] = a[0]*a[1]*a[2]     *a[4];

           b[4] = a[0]*a[1]*a[2]*a[3];

  b)这里采用分段法,即以缺少的元素为界限分成两段,先求左边的一段(灰色部分),可以看到除b[0]外是依次相乘的,题目中不让申请其余变量,因此我们可以暂时使用b[0]作为中间变量,存储a中元素相乘后的值,然后在赋值给b,同理右半部分也是这么求解的。

3.程序

#include <stdio.h>

#define N 5
/*
 * b[i] = a[0]*.....*a[N-1]/a[i];
 * 复杂度 分别为O(n) 和  O(1)
 */

int main(int argc, const char *argv[])
{
    int a[N] = {5, 2, 3, 7, 4};
    int b[N];

    //前半段
    b[0] = 1; //以b[0]为中介
    int i;
    for(i = 1; i < N; i++){
        b[0] *= a[i-1];
        b[i] = b[0];
    }

    //后半段
    b[0] = 1;
    for(i = N-2; i > 0; i--){
        b[0] *= a[i+1];
        b[i] *= b[0];
    }
    b[0] *= a[1];

    //输出
    for(i = 0 ; i < N; i++){
        printf("%4d\t", b[i]);
    }
    printf("\n");

    return 0;
}

  

0810------笔试题----------腾讯2012年的一道笔试题,布布扣,bubuko.com

时间: 2024-07-30 13:46:19

0810------笔试题----------腾讯2012年的一道笔试题的相关文章

【笔试题-腾讯】给定一个数组a[N],我们希望构造数组b[N]

腾讯2012实习生笔试题(加分题): 给定一个数组a[N],我们希望构造数组b[N],其中b[i]=a[0]*a[1]*...*a[N-1]/a[i].在构造过程: a)不允许使用除法: b)要求O(1)空间复杂度和O(n)时间复杂度: c)除遍历计数器与a[N] b[N]外,不可使用新的变量(包括栈临时变量.对空间和全局静态变量等): 请用程序实现并简单描述. 题意应该不难理解,乍一看有点儿无从下手的感觉,思考后没有突破的话就想放弃了.看到网上其他同学也给出了解法,代码很简洁,但是理解起来不是

腾讯web前端开发工程师笔试题及答案

1. 如何实现事件委托? 首先要知道什么是事件委托. 考虑一个列表,在li的数量非常少的时候,为每一个li添加事件侦听当然不会存在太多性能方面的问题,但是当列表非常的长,长到上百上千甚至上万的时候(当然只是一个解释,实际工作中很少遇到这么多li的情况),为每个li添加事件侦听就会对页面性能产生很大的影响. 就像下面这段代码: <!DOCTYPE HTML><html><head><meta charset="utf-8" /><ti

Java中有关构造函数的一道笔试题解析

Java中有关构造函数的一道笔试题解析 1.具体题目如下 下列说法正确的有() A. class中的constructor不可省略 B. constructor必须与class同名,但方法不能与class同名 C. constructor在一个对象被new时执行 D.一个class只能定义一个constructor 2.解析说明 (1)class中的构造函数是可以省略的 /** * @Title:User.java * @Package:com.you.user.model * @Descrip

关于阿里的一道笔试题分析

其题目如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 #pragma pack(2) class A { public:     int i;     union U     {         char buff[13];         int i;     }u;     void foo() {    }     typedef char* (*f)(void*);     enum{red, green, blue} color; }a; class A

好玩的一道笔试题

/*实现函数: void f(int a, int b, int c) 编码中不允许出现燃和if,switch,for,while之类的关键词以及"?:"表达式,并要求: a=1时,打印b+c的值: a=2时,打印b-c的值: a=3时,打印b*c的值: a=4时,打印b/c的值. */ 下面是我的解答,哈哈: #include <iostream> int cal(int a,int b, int c){ int res = 0; (!(a^1) && (

送上今年微软的一道笔试题

这里送上一道微软的笔试题,具体题目如下: Time Limit: 10000msCase Time Limit: 1000msMemory Limit: 256MB Description Consider a string set that each of them consists of {0, 1} only. All strings in the set have the same number of 0s and 1s. Write a program to find and outp

给定一个数值,输出符合中国人习惯的读法--记一道笔试题

题目:给定一个数字,最大小于一万亿,输出符合中国人习惯的读法,例如: a.12输出:十二 b.102输出:一百零二 c.1002输出:一千零二 d.112输出:一百十二 e.10112输出:一万零一百十二 f.120000000:一亿二千万 g.11021002:一千一百零二万一千零二 h.11020102:一千一百零二万零一百零二 i.1000001:一百万零一 j.1000000001:十亿零一 嗯,一道笔试题,解的很没有节操,没有太好的思路,只能尽力抽取翻译过程中的共有代码,尽量写的不那么

一道笔试题来理顺Java中的值传递和引用传递

前段时间参加了一场面试,其中有一道引用传递的题,因为当时并没有考虑清楚所以做错了. 现在来复盘一下,题目如下: private static void change(StringBuffer str11, StringBuffer str12) { str12 = str11; str11 = new StringBuffer("new world"); str12.append("new world");} public static void main(Stri

【转】腾讯高级工程师:一道面试题引发的高并发性能调试思考

https://dbaplus.cn/news-21-625-1.html 这样打破沙锅问到底的精神十分可贵!注意其中用到的工具 4月份的时候看到一道面试题,据说是腾讯校招面试官提的:在多线程和高并发环境下,如果有一个平均运行一百万次才出现一次的bug,你如何调试这个bug?(知乎原贴地址如下:https://www.zhihu.com/question/43416744) 遗憾的是知乎很多答案在抨击这道题本身的正确性,虽然我不是这次的面试官,但我认为这是一道非常好的面试题.当然,只是道加分题,