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

            jake1036

            在一數(shù)組中刪除特定數(shù)據(jù)

              在一數(shù)組中刪除某一特定數(shù)據(jù)

             一 問題描述:
                 在一個(gè)整型數(shù)組中刪除某一個(gè)特定數(shù)據(jù)。

             二 問題分析:
                 (1)最簡單的方法:
                        遍歷數(shù)組,發(fā)現(xiàn)當(dāng)前的數(shù)據(jù)a[i]為特定數(shù)據(jù),則將i之后的數(shù)據(jù)依次前移一個(gè)位置,并減少數(shù)組的長度。
                        然后運(yùn)用相似的辦法,依次遍歷剩余的數(shù)據(jù)。
                        這樣的時(shí)間復(fù)雜度為o(n*n) ,而空間復(fù)雜度為o(n)。
                  (2)簡單方法:
                          內(nèi)存中維持兩個(gè)簡單變量num表示含有的特定數(shù)據(jù)的個(gè)數(shù),而len則表示數(shù)組的長度。
                          num初始化為0,然后每當(dāng)判斷為特定的數(shù)據(jù)時(shí),則執(zhí)行num++,len--。
                          對(duì)于非特定的數(shù)據(jù),則執(zhí)行a[i-num] = a[i],即將之后的數(shù)據(jù)前移,實(shí)現(xiàn)刪除功能。
                         時(shí)間復(fù)雜度為o(n) ,空間復(fù)雜度為o(n)。
             三 代碼如下:
                

            #include <iostream>
             
            using namespace std;
             
            /*
              刪除數(shù)組中的元素5,并將其余元素移動(dòng)到前方 
             
             
            */

             
            const int N = 12 ;
             
            int a[N] = {2 ,4 ,5 ,6,3 ,5 ,4 ,5 ,7,2,5,7} ;
             
             
            int change() //返回改變之后的數(shù)組長度 
             {
               
            int num = 0 ; //統(tǒng)計(jì)5個(gè)個(gè)數(shù) 
               int len = N ; //len表示數(shù)組長度。作為返回值 
               for(int i = 0 ; i < N ;i++)
               
            {
                
                 
            if(a[i] == 5
                 
            {
                   num
            ++ ;
                   len
            -- ;       
                 }

                  
            else
                  
            {   
                  a[i
            -num] = a[i] ;
                  
                  }
                   
               }

                
            return len ;   
             }

             
             
             
            int main()
             
            {
               
            int len = change() ;
               
            for(int i = 0 ; i < len ; i++)
                cout
            <<a[i]<<" " ;
                cout
            <<endl ;  
              getchar() ;   
              
            return 0 ;     
             }


             

            posted on 2011-06-29 14:01 kahn 閱讀(1018) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久久久99精品成人片| 欧美亚洲国产精品久久高清| 久久婷婷五月综合色高清| 99久久精品午夜一区二区| 久久福利片| 麻豆亚洲AV永久无码精品久久| 久久精品中文字幕久久| 亚洲伊人久久成综合人影院 | 一本久久a久久精品综合夜夜 | 老司机国内精品久久久久| 少妇久久久久久被弄到高潮 | 久久精品国产亚洲AV不卡| 香蕉久久av一区二区三区| 久久伊人亚洲AV无码网站| 99久久成人国产精品免费 | 久久久WWW成人免费精品| 热re99久久6国产精品免费| 久久综合九色欧美综合狠狠| 99久久中文字幕| 97精品伊人久久久大香线蕉| 国产—久久香蕉国产线看观看| 人妻丰满AV无码久久不卡| 日本高清无卡码一区二区久久| 91精品无码久久久久久五月天| 人妻精品久久久久中文字幕一冢本| 久久中文字幕无码专区| 国产午夜精品久久久久九九| 精品999久久久久久中文字幕| 人妻无码αv中文字幕久久琪琪布| 7777精品伊人久久久大香线蕉| 精品久久久久中文字幕一区| 久久精品国产秦先生| 久久精品这里热有精品| 青青草国产成人久久91网| 久久亚洲高清观看| 中文字幕久久欲求不满| 久久婷婷久久一区二区三区| 亚洲国产成人久久综合一| 99久久精品免费看国产一区二区三区 | 色婷婷综合久久久久中文 | 麻豆一区二区99久久久久|