C++ Jounior

once setback,once inspiration,once self-awareness
重要的是这个磨练过程,而不是结果,要的是你粗壮的腿,而不是你身上背的那袋盐巴

 

排序

// 一、冒泡排序(Bubble)   



namespace  BubbleSorter
{
    
public   class  BubbleSorter
    
{
        
public   void  Sort( int [] list)
        
{
            
int  i, j, temp;
            
bool  done  =   false ;
            j 
=   1 ;
            
while  ((j  <  list.Length)  &&  ( ! done))
            
{
                done 
=   true ;
                
for  (i  =   0 ; i  <  list.Length  -  j; i ++ )
                
{
                    
if  (list[i]  >  list[i  +   1 ])
                    
{
                        done 
=   false ;
                        temp 
=  list[i];
                        list[i] 
=  list[i  +   1 ];
                        list[i 
+   1 =  temp;
                    }

                }

                j
++ ;
            }

        }

    }


    
public   class  MainClass
    
{
        
public   static   void  Main1()
        
{
            
int [] iArrary  =   new   int []  1 5 13 6 10 55 99 2 87 12 34 75 33 47  } ;
            BubbleSorter sh 
=   new  BubbleSorter();
            sh.Sort(iArrary);
            
for  ( int  m  =   0 ; m  <  iArrary.Length; m ++ )
                Console.Write(
" {0}  " , iArrary[m]);
            Console.WriteLine();
        }

    }

}
   
  
// 二、选择排序(Selection)   



namespace  SelectionSorter
{
    
public   class  SelectionSorter
    
{
        
private   int  min;
        
public   void  Sort( int [] list)
        
{
            
for  ( int  i  =   0 ; i  <  list.Length  -   1 ; i ++ )
            
{
                min 
=  i;
                
for  ( int  j  =  i  +   1 ; j  <  list.Length; j ++ )
                
{
                    
if  (list[j]  <  list[min])
                        min 
=  j;
                }

                
int  t  =  list[min];
                list[min] 
=  list[i];
                list[i] 
=  t;
            }

        }

    }


    
public   class  MainClass2
    
{
        
public   static   void  Main2()
        
{
            
int [] iArrary  =   new   int []  1 5 3 6 10 55 9 2 87 12 34 75 33 47  } ;
            SelectionSorter ss 
=   new  SelectionSorter();
            ss.Sort(iArrary);
            
for  ( int  m  =   0 ; m  <  iArrary.Length; m ++ )
                Console.Write(
" {0}  " , iArrary[m]);
            Console.WriteLine();
        }

    }

}
   
  
// 三、插入排序(InsertionSorter)   



namespace  InsertionSorter
{
    
public   class  InsertionSorter
    
{
        
public   void  Sort( int [] list)
        
{
           
            
for  ( int  i  =   1 ; i  <  list.Length; i ++ )
            
{
                
int  t  =  list[i];
                
int  j  =  i;
                
// 依次往前推。
                
// 先是前两个元素。
                
// 然后是前三个元素。
                
// 然后是前N个元素。
                 while  ((j  >   0 &&  (list[j  -   1 >  t))
                
{
                    list[j] 
=  list[j  -   1 ];
                    
-- j;
                }

                list[j] 
=  t;
            }

        }

    }


    
public   class  MainClass3
    
{
        
public   static   void  Main3()
        
{
            
int [] iArrary  =   new   int []  1 13 3 6 10 55 98 2 87 12 34 75 33 47  } ;
            InsertionSorter ii 
=   new  InsertionSorter();
            ii.Sort(iArrary);
            
for  ( int  m  =   0 ; m  <  iArrary.Length; m ++ )
                Console.WriteLine(
" {0} " , iArrary[m]);
            Console.WriteLine();
        }

    }

}
   
  
/*
   * 有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序,这个时候就要用到一种新的排序方法——插入排序法,插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据。

void  insertSort(Type* arr,long len) //InsertSort algorithm
{
       long i=0,j=0;//iterator value
       Type tmpData;
       assertF(arr!=NULL,"In InsertSort sort,arr is NULL\n");
       for(i=1;i<len;i++)
       {
              j=i;
              tmpData=arr;
              while(tmpData<arr[j-1]&&j>0)
              {
                     arr[j]=arr[j-1];
                     j--;
              }
              arr[j]=tmpData;
       }
}
插入排序算法思路是:
假定这个数组的序是排好的,然后从头往后,如果有数比当前外层元素的值大,则将这个数的位置往后挪,直到当前外层元素的值大于或等于它前面的位置为止.这具算法在排完前k个数之后,可以保证a[1…k]是局部有序的,保证了插入过程的正确性.

   
*/

// 四、希尔排序(ShellSorter)   



namespace  ShellSorter
{
    
public   class  ShellSorter
    
{
        
public   void  Sort( int [] list)
        
{
            
int  inc;
            
for  (inc  =   1 ; inc  <=  list.Length  /   9 ; inc  =   3   *  inc  +   1 ) ;
            Console.WriteLine(
" {0}--- " ,inc);

            
for  (; inc  >   0 ; inc  /=   3 )
            
{
                Console.WriteLine(
" {0} around " , inc);
                
for  ( int  i  =  inc  +   1 ; i  <=  list.Length; i  +=  inc)
                
{
                    
// inc 是间隔
                    
// j 是每几个元素,1为开始坐标
                     int  t  =  list[i  -   1 ]; // “被比较的数”的元素放到 t 中
                     int  j  =  i;                    
                    
while  ((j  >  inc)  &&  (list[j  -  inc  -   1 >  t))
                    
{ // 因为要比较的数(前面的数)大于“被比较的数”
                        list[j  -   1 =  list[j  -  inc  -   1 ];
                        j 
-=  inc; // 移动比较元素
                    }

                    list[j 
-   1 =  t; // 最后把 t 放在比较范围的每个位置
                }

            }

        }

    }


    
public   class  MainClass4
    
{
        
public   static   void  Main4()
        
{ //                               0  1  2   3  4  5
             int [] iArrary  =   new   int []  15 5 13 6 10 55 99 2 87 12 34 75 33 47  } ;
            ShellSorter sh 
=   new  ShellSorter();
            sh.Sort(iArrary);
            
for  ( int  m  =   0 ; m  <  iArrary.Length; m ++ )
                Console.WriteLine(
" {0}  " , iArrary[m]);
            Console.WriteLine();
        }

    }

}




/* 希尔排序(缩小增量法) 
属于插入类排序,是将整个无序列分割成若干小的子序列分别进行插入排序  
排序过程:先取一个正整数d1<n,把所有序号相隔d1的数组元素放一组,
 * 组内进行直接插入排序;然后取d2<d1,重复上述分组和排序操作;
 * 直至di=1,即所有记录放进一个组中排序为止   
    
  初始:d=5   
          49   38   65   97   76   13   27   49*   55   04   
           |----------------------------|   
               38                              27   
                   |---------------------------|   
                        65                              49*       
                         |----------------------------|   
                                97                              55   
                                  |--------------------------|   
                                      76                                04
                                        |-----------------------------| 
  一趟结果   
          13   27   49* 55   04   49   38   65     97     76  
  d=3
          13   27   49* 55   04   49   38   65     97     76  
             |---------------|----------------|--------------------|   
                  27                04                 65   
                   |----------------|----------------|   
                         49*               49                  97   
                           |----------------|-----------------|   
  二趟结果   
            13   04   49* 38   27   49   66   65   97   76   
  d=1   
            13   04   49* 38   27   49   66   65   97   76   
              |-----|-----|-----|-----|-----|-----|-----|-----|-----|
  三趟结果   
            04   13   27   38   49* 49   55   65   76   97    
*/

posted on 2008-04-02 09:26 snowball 阅读(221) 评论(0)  编辑 收藏 引用 所属分类: 算法+数据结构


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


导航

留言簿(1)

随笔分类

友情链接

搜索

最新随笔

最新评论

阅读排行榜