• <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

            題目轉(zhuǎn)自:
            http://blog.163.com/ecy_fu/blog/static/444512620098228849190/
             二筆只有三道題,分值分別為30, 30, 40,題分別如下:
            1、實(shí)現(xiàn)strtol函數(shù),其原型如為int strtol(const char *num_str, char **endptr, int base),num_str存放待轉(zhuǎn)換的字符串,可以是負(fù)數(shù)也可以是正數(shù);endptr指向第一個(gè)非法字符的地址,如果endptr為NULL則不指向第一個(gè)非法字符的地址;base用于指示進(jìn)制,若base為0,則根據(jù)num_str的指示來(lái)轉(zhuǎn)換。函數(shù)必須檢查溢出,如果正數(shù)溢出,返回INT_MAX;若負(fù)數(shù)溢出,返回INT_MIN。
            2、一億個(gè)數(shù)找最大的1000個(gè)數(shù),要求效率高占用內(nèi)存少。函數(shù)原型為:find_max_data(int* source_data, int* max_data),其中source_data是存放一億個(gè)數(shù)的數(shù)組,max_data用于存放其中最大的1000個(gè)數(shù)。
            3、將一個(gè)集合拆分成兩個(gè)不相交的子集,兩個(gè)子集元素之和相等,如{1, 2, 3, 4, 5, 6, 7},拆分成:
            {2, 5, 7}, {1, 3, 4, 6}
            給出一個(gè)集合,求所有符合上面要求的拆分,效率最高分越高,函數(shù)原型為int cal_num(int n);

            第三題:
            利用回溯剪枝法
            空間復(fù)雜度:O(n) 棧的最大深度也就是n了
            時(shí)間復(fù)雜度:接近于O(2^n-1), 因?yàn)楸举|(zhì)上程序時(shí)一個(gè)遍歷樹(shù)的過(guò)程,如果沒(méi)有剪枝,那么樹(shù)是一個(gè)滿二叉樹(shù),結(jié)點(diǎn)共2^n-1個(gè),也就要遍歷2^n-1次。雖然剪枝,但速度估計(jì)仍是 2^n次方級(jí)別的。
            試了下,調(diào)用cal_num(104),好久了結(jié)果都沒(méi)有出來(lái)。。。

            不知用上DP算法會(huì)不會(huì)好點(diǎn),不過(guò)聽(tīng)說(shuō)回溯法怎么弄效率都跟不上,最好用遞推?
            在哪聽(tīng)說(shuō)的?
            http://topic.csdn.net/u/20090922/11/ebc26b48-6581-40c3-afe0-a95ca2d700d5.html

             

            /////////////////////////////////////////////////////////////////
            //file divide_set.h:

            #ifndef __DIVIDE_SET_H__
            #define __DIVIDE_SET_H__

            // 計(jì)算集合set的所有滿足下列條件的子集合:子集合元素之和等于value
            // 子集合的元素對(duì)應(yīng)的label置1
            void divide_set( int set[], int label[], int len, int i_set, int value );

            // 對(duì)集合{1,2,n}劃分
            void cal_num( int n );

            #endif


            /////////////////////////////////////////////////////////////////
            //file divide_set.cpp:

            #include 
            "stdafx.h"
            #include 
            "divide_set.h"

            #include 
            <iostream>

            using namespace std;

            // 查找集合set中,滿足元素之和等于value的子集合,結(jié)果存于label里
            void divide_set( int set[], int label[], int len, int i_set, int value )
            {
             
            // 輸出結(jié)果
             if ( value == 0 )
             
            {
              cout
            <<"";
              
            for ( int i=0; i<len; ++i )
              
            {
               
            if ( label[i] )
               
            {
                cout
            <<set[i]<<" ";
               }

               
              }

              cout
            <<"";
              cout
            <<" , { ";
              
            for ( int i=0; i<len; ++i )
              
            {
               
            if ( 0 == label[i] )
               
            {
                cout
            <<set[i]<<" ";
               }

              }

              cout
            <<"";
              cout
            <<endl;
              
            return;
             }


             
            if ( i_set >= len || value <0)
             
            {
              
            return;
             }


             
            // 取第i_set個(gè)元素
             label[i_set] = 1;
             divide_set( 
            set, label, len, i_set+1, value-set[i_set] );
             
             
            // 不取第i_set個(gè)元素
             label[i_set] = 0;
             divide_set( 
            set, label, len, i_set+1, value );
            }


            void cal_num( int n )
            {
             
            int* set = new int[n];
             
            int* label = new int[n];

             
            // initialize set and label
             int sum_value = 0;
             
            for ( int i=0; i<n; ++i )
             
            {
              
            set[i] = i+1;
              sum_value 
            += set[i]; 
             }

             memset( label, 
            0, n*sizeof(int) );

             
            // 保證元素總和為偶數(shù)
             if( sum_value%2 == 0 )
              divide_set( 
            set, label, n, 0, sum_value/2 );

             delete[] 
            set;
             delete[] label;
            }


             

            本文來(lái)自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/zdl1016/archive/2009/10/04/4632688.aspx

            posted on 2009-10-07 11:08 life02 閱讀(524) 評(píng)論(1)  編輯 收藏 引用 所屬分類: 筆試

            評(píng)論

            # re: 迅雷2010筆試題-成都站 (轉(zhuǎn))[未登錄](méi) 2009-10-07 19:38 vincent
            第一題 - -都看不懂..orz
            第二題 用一個(gè)長(zhǎng)度為1000的小頭堆..每次拿一個(gè)數(shù)跟小頭堆的頭來(lái)比..如果大于..就把小頭堆的頭去掉..然后放進(jìn)這個(gè)數(shù)
            第三題 這個(gè)要看題的范圍了吧..dp的話就是背包了..

              回復(fù)  更多評(píng)論
              

            久久久噜噜噜久久熟女AA片| 久久精品国产亚洲AV不卡| 久久久久人妻一区精品色| 久久精品免费一区二区三区| 亚洲伊人久久综合影院| 国产精品久久一区二区三区| 亚洲精品乱码久久久久久蜜桃| 久久免费的精品国产V∧| 久久精品国产亚洲AV不卡| 色欲综合久久中文字幕网| 久久天天躁狠狠躁夜夜2020| 国产午夜福利精品久久2021 | 久久青青国产| 无码人妻久久一区二区三区| 久久精品18| 国产精品久久久久久| 久久精品国产清自在天天线| 精品无码久久久久久国产| 国产成人无码久久久精品一| A级毛片无码久久精品免费| 久久精品无码av| 亚洲伊人久久大香线蕉苏妲己| 久久不见久久见免费视频7| 亚洲午夜福利精品久久| 久久精品99无色码中文字幕| 亚洲天堂久久精品| 99国产精品久久| 国产成人久久AV免费| 亚洲精品午夜国产VA久久成人| 尹人香蕉久久99天天拍| 久久久久久噜噜精品免费直播| 精品无码人妻久久久久久| 91精品国产91久久久久久| 国产亚洲欧美成人久久片| 亚洲国产另类久久久精品小说| 久久精品青青草原伊人| 欧美亚洲国产精品久久| 久久婷婷五月综合色奶水99啪| 伊人久久大香线蕉综合热线| 久久人与动人物a级毛片| 久久亚洲AV无码精品色午夜麻豆|