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

            在一數組中刪除特定數據

              在一數組中刪除某一特定數據

             一 問題描述:
                 在一個整型數組中刪除某一個特定數據。

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

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

             
            const int N = 12 ;
             
            int a[N] = {2 ,4 ,5 ,6,3 ,5 ,4 ,5 ,7,2,5,7} ;
             
             
            int change() //返回改變之后的數組長度 
             {
               
            int num = 0 ; //統計5個個數 
               int len = N ; //len表示數組長度。作為返回值 
               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 閱讀(1010) 評論(0)  編輯 收藏 引用

            亚洲狠狠久久综合一区77777| 国内精品久久久久久中文字幕| 国产精品久久久久久久人人看| 久久SE精品一区二区| 久久香综合精品久久伊人| 99麻豆久久久国产精品免费| 国产午夜精品久久久久九九电影 | 久久这里只精品99re66| 精品国产99久久久久久麻豆| 99re久久精品国产首页2020| 亚洲另类欧美综合久久图片区| 亚洲AV日韩精品久久久久| 久久99热这里只有精品国产| 久久久久亚洲av无码专区喷水 | 国产精品99久久久精品无码 | 国产成人久久AV免费| 日韩精品无码久久一区二区三| 久久国产亚洲精品麻豆| 亚洲精品第一综合99久久| 亚洲国产精品久久久久久| 亚洲国产精品高清久久久| 无码人妻久久一区二区三区蜜桃| 久久国产精品77777| 久久精品国产清自在天天线 | 精品久久久久久久国产潘金莲 | 久久国产高潮流白浆免费观看| 久久婷婷午色综合夜啪| 伊人久久综合热线大杳蕉下载| 久久夜色精品国产噜噜麻豆 | 亚洲精品乱码久久久久久按摩 | 久久久久久久久久久久中文字幕 | 久久综合狠狠综合久久综合88 | 亚洲精品无码久久毛片| 欧美性猛交xxxx免费看久久久| 久久国产成人亚洲精品影院| 一本大道加勒比久久综合| av国内精品久久久久影院| 国产精品一区二区久久精品| 高清免费久久午夜精品| 精品久久久久久国产潘金莲| 久久精品国产一区二区三区日韩|