• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            life02

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              197 隨筆 :: 3 文章 :: 37 評(píng)論 :: 0 Trackbacks

            2009.9.12日下午 迅雷2筆試題

            有一副牌編號(hào)0~51,請(qǐng)把這副牌盡可能隨機(jī)的發(fā)到4個(gè)人手里
            注1:已經(jīng)有rand()函數(shù)可以調(diào)用,但是rand()函數(shù)開(kāi)銷較大,請(qǐng)盡量少調(diào)用

            a,b,c,d分別是13個(gè)元素的1維數(shù)組
            函數(shù)原型 void deal( int[] a, int[] b, int[] c, int[] d );


            實(shí)現(xiàn)字符串反轉(zhuǎn)的c庫(kù)函數(shù) char* strrev(char* string)
            注1:不可利用其他庫(kù)函數(shù),算法盡量高效、占用空間少。


            有10億個(gè)數(shù),這些數(shù)的值都在0~1000萬(wàn)之內(nèi)。實(shí)現(xiàn)接口 get_bigger_count( unsigned value )
            輸入一個(gè)值value,返回這10億個(gè)數(shù)中比value值大的數(shù)的數(shù)目。
            class order_calculate
            {
            public:
            order_calculate();
            ~order_calculate();
            unsinged get_bigger_count( unsigned value )
            }
            注1:get_bigger_count接口會(huì)被頻繁的調(diào)用,實(shí)現(xiàn)要高效
            注2:可以自己往內(nèi)部任意添加變量和接口
            注3:有個(gè)現(xiàn)成的接口 unsigned get_value_by_index( int idx ) 可以調(diào)用,該接口返回指定索引的value值
                 比如 get_value_by_index( 100 ), 返回10億個(gè)數(shù)中第100個(gè)數(shù)的值。該接口開(kāi)銷較大,盡量少調(diào)用。



            http://topic.csdn.net/u/20090912/20/8c60e06e-321c-49a6-b2cc-59248ba9cf36.html?28642 

            posted on 2009-09-13 16:29 life02 閱讀(783) 評(píng)論(2)  編輯 收藏 引用 所屬分類: 筆試

            評(píng)論

            # re: 筆試題 2009-09-14 18:16 life02
            第三題正解如下:
            這題很明顯已經(jīng)告訴各位了,算法復(fù)雜度是o(1),任何其他排序算法都是錯(cuò)的,只有桶排序可行,原因也很明顯,符合桶排序的特征,0到1000萬(wàn)的取值范圍已經(jīng)固定了,相對(duì)10億來(lái)說(shuō)1000萬(wàn)是很小了。

            所以只要設(shè)立0到1000萬(wàn)的桶,中間附加計(jì)數(shù)即可,什么意思呢,10億個(gè)數(shù)據(jù),如果縮小一點(diǎn):范圍是0到10的話
            0,1,2,3,4,5,6,7,8,9,10

            在每一個(gè)桶下面掛一個(gè)count,掃描完后,10億個(gè)數(shù)據(jù)肯定都在這10個(gè)桶里(1000萬(wàn)類似)

            這樣在接下來(lái)查詢的時(shí)候,其實(shí)比較空間只有0到1000萬(wàn),和10億一點(diǎn)關(guān)系都沒(méi)有,而且每個(gè)桶還幫你記著大于該數(shù)的個(gè)數(shù),所以假定要比較的數(shù)值是5,則結(jié)果就是5,6,7,8,9,10的count之和。

            計(jì)算空間最大浪費(fèi)就是在0到1000萬(wàn)里面,找到你的那個(gè)數(shù)值,但是總比N要小很多,這個(gè)結(jié)論拿出去,面試來(lái)說(shuō),應(yīng)該可以得滿分,至于效率,空間什么的,就自己優(yōu)化1000萬(wàn)數(shù)據(jù)的比較算法啦。  回復(fù)  更多評(píng)論
              

            # re: 筆試題 2009-09-18 10:09 life02
            #include <iostream>
            #include <stdio.h>
            #include <assert.h>
            using namespace std;


            static unsigned int *pindex;

            #define L 10000001
            unsigned get_bigger_count(unsigned value)
            {
            assert(value<L-1);
            static binit(false);
            unsigned int rval(0);
            if(!binit)
            {
            FILE *fp = fopen("datafile", "r+b");
            unsigned int i = 0;
            unsigned int shu;
            pindex = new unsigned int[L];
            memset(pindex, 0, sizeof(unsigned int)*L);

            while(fscanf(fp,"%ld",&shu)!=-1){
            /* cout<<shu<<endl;*/
            pindex[shu]++;
            }
            fclose(fp);
            for(i=L-1; i>0; --i)
            pindex[i-1] += pindex[i];
            }
            binit = true;
            rval = pindex[value+1];
            return rval;
            }




            int main(){
            unsigned un;
            un=get_bigger_count(8738787);
            cout<<un<<endl;
            return 0;
            }  回復(fù)  更多評(píng)論
              

            久久久久久国产精品免费免费| 日日狠狠久久偷偷色综合0| 免费精品久久天干天干| 精品伊人久久大线蕉色首页| AV无码久久久久不卡网站下载 | 午夜欧美精品久久久久久久| 亚洲AV无一区二区三区久久 | 成人国内精品久久久久影院VR | 国产精品99久久久久久猫咪| 久久久久免费视频| 狠狠色噜噜色狠狠狠综合久久| 无码国产69精品久久久久网站| 草草久久久无码国产专区| 久久综合色老色| 欧美精品一区二区精品久久| 精品久久久久久无码中文字幕一区| 97超级碰碰碰碰久久久久| 99蜜桃臀久久久欧美精品网站| 国产巨作麻豆欧美亚洲综合久久| 色综合久久无码五十路人妻| 欧美日韩精品久久久免费观看| 久久精品成人免费网站| 伊人久久大香线蕉AV色婷婷色| 品成人欧美大片久久国产欧美...| 无码超乳爆乳中文字幕久久| 综合久久一区二区三区| 久久久久九九精品影院| 一本久久a久久精品综合夜夜| 久久久久久九九99精品| 亚洲级αV无码毛片久久精品| 亚洲国产精品无码久久久久久曰| 99久久国产综合精品成人影院| 国产成人久久激情91| 久久99精品国产麻豆| 国内精品久久久久久久97牛牛| 久久精品亚洲日本波多野结衣 | 色综合久久久久综合体桃花网| 久久综合久久综合亚洲| 久久经典免费视频| 久久亚洲精品成人无码网站| 久久久久久免费视频|