C# 排序--小测试

复制代码
代码
            int[] source = new int[] { 1343453 };
            printInt(source);
            
//从小到大排序
            /*   //选择
            for (int i = 0; i < source.Length; i++)
            {
                for (int j = i + 1; j < source.Length; j++)
                {
                    //前面的比后面的大,则调换位置
                    if (source[i] > source[j])
                    {
                        int temp = source[i];
                        source[i] = source[j];
                        source[j] = temp;
                    }
                }
            }
*/
            
/*  //冒泡
            int j = 1;
            bool done = false;
            while(j<source.Length && !done)
            {
                done = true;
                for (int i = 0; i < source.Length-1; i++)
                {    
                    //[相邻的俩比较]前面的比后面的大,则调换前后位置
                    if (source[i] > source[i+1])
                    {
                        done =false;
                        int temp = source[i];
                        source[i] = source[i+1];
                        source[i+1] = temp;
                    }                 
                }
                j++;
            }
*/
            
//插入法排序
            for (int i = 1; i < source.Length ; i++)
            {
                
int temp = source[i];
                
int j = i;
                
while (j>0 && source[j-1]>temp)
                {
                    source[j] 
= source[j - 1];
                    j
--;
                }
                source[j] 
= temp;
            }
复制代码

测试下排序.

1。数组定义,并初始化int[] source = new int[] { 1, 34, 3, 45, 3 };

2。打印数组,用for循环打印

3。排序思想[以从小到大为例]

(1)i=0;i<长度;i++ ; { j =i+1;j<长度;j++ .拿第i个与第i之后的所有(j)依次比较,若i处大于后者,则调换位置----一轮下来,i处放的是未排序的数值中最小的.--称选择排序

(2)j=1;flag=fasle while(j<长度且flag为false){for(i=1;i<长度-1;i++) 哪相邻的俩(i与i+1)比较,小的放前面----一轮下来,最大的被放到了最后.---称为冒泡排序

(3)i=1;i<长度,i+{记下i处值,j=i while(i之前(j处)若有比i处大的,则让i处值等于较大的 ) j处等于i处值原始值----一轮下来,i处是已排序的i个值中最大的--称插入排序

posted @   9421  阅读(184)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示