标题:求:C#冒泡程序
只看楼主
f2831890
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:115
专家分:107
注 册:2009-11-25
结帖率:96.77%
已结贴  问题点数:20 回复次数:9 
求:C#冒泡程序
要求:从键盘里输入数值
搜索更多相关主题的帖子: 冒泡 
2010-04-09 22:32
athenalux
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河北石家庄
等 级:小飞侠
威 望:8
帖 子:975
专家分:2514
注 册:2008-11-26
得分:5 
自从用了VS以后,渐渐地用记事本就写不出完整的代码了~~,所以只说下逻辑吧。
冒泡就是把一组数中,相邻两个的数比较大小,如果较小的数在前面,就把这两个数交换位置,否则不交换。经过一个嵌套循环,最后就可能把数字按从小到大,或从大到小排列好。

QQ:81704464
2010-04-10 14:32
chenkb730
Rank: 2
等 级:论坛游民
帖 子:39
专家分:44
注 册:2010-3-22
得分:15 
using System;
using System.Collections.Generic;
using System.Text;

namespace 冒泡排序
{
    class Program
    {
        static void Main(string[] args)
        {
           double[] arr=new double[3];
           double temp;
           Console.WriteLine("请输入3个数:");
            for(int i=0;i<arr.Length;i++)
            {
                arr[i]=double.Parse(Console.ReadLine());
            }
            for (int i = 0; i < arr.Length; i++)
            {
                for (int j = i; j < arr.Length; j++)
                    if (arr[i] > arr[j])
                    {
                        temp = arr[i];
                        arr[i] = arr[j];
                        arr[j] = temp;
                    }
            }
            Console.WriteLine("结果:");
            for (int i = 0; i < arr.Length; i++)
            {
                Console.WriteLine(arr[i]);
        

            }
           Console.ReadLine();  
        }
    }
}
2010-04-10 17:58
f2831890
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:115
专家分:107
注 册:2009-11-25
得分:0 
谢谢!!!!!

QQ:412869766
2010-04-10 22:26
work001
Rank: 3Rank: 3
等 级:禁止访问
帖 子:76
专家分:114
注 册:2010-4-9
得分:0 
不错,不错。。。。
2010-04-11 14:46
ouxianzhi520
Rank: 8Rank: 8
来 自:重庆
等 级:蝙蝠侠
威 望:3
帖 子:245
专家分:932
注 册:2007-12-1
得分:0 
回复 3楼 chenkb730
你这个可以实现排序的功能,但不是冒泡排序的算法吧。
我以前也是这样写的冒泡排序,但昨天才发现这种写法是错误的。
循环里面应该是这样的
(for int i = 0 ;i <array.Length;i++)
(for in j = 0 ;j<array.Length-i-1;j++)
{
if(array[j]<array[j+1])
 {
   int temp =array[j];
   array[j]= array[j+1];
   array[j+1] = temp;
 }
}

 

[url=http://blog./ouxianzhi520]csdn个人博客[/url]
2010-04-12 20:41
chenkb730
Rank: 2
等 级:论坛游民
帖 子:39
专家分:44
注 册:2010-3-22
得分:0 
以下是引用ouxianzhi520在2010-4-12 20:41:23的发言:

你这个可以实现排序的功能,但不是冒泡排序的算法吧。
我以前也是这样写的冒泡排序,但昨天才发现这种写法是错误的。
循环里面应该是这样的
 
所谓的冒泡排序就是先进行一轮排序,找出做大或最小的排在第一位,再从第二位开始进行下一轮排序,如此循环而已
楼上的排序法虽然是可以,可原理是一样的...只是楼上的程序比较规范而已...
2010-04-13 08:15
ouxianzhi520
Rank: 8Rank: 8
来 自:重庆
等 级:蝙蝠侠
威 望:3
帖 子:245
专家分:932
注 册:2007-12-1
得分:0 
回复 7楼 chenkb730
冒泡排序(BubbleSort)的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再小于第2个数),将小数放前,大数放后,一直比较到最大数前的一对相邻数,将小数放前,大数放后,第二趟结束,在倒数第二个数中得到一个新的最大数。如此下去,直至最终完成排序。
  由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。

我这写了一个区别,二者的过程完全不是一致的。冒泡排序是比较的想邻的两个数。
程序代码:
 static void Main(string[] args)
        {
            int[] array = new int[] { 3, 4, 2, 1, 6, 5 };
            Console.Write("排序前:");
            for (int i = 0; i < array.Length;i++ )
                Console.Write("array[{0}]={1}  ", i, array[i]);
            sord1(array);
            Console.Write("排序后:");
            for (int i = 0; i < array.Length; i++)
                Console.Write("array[{0}]={1}  ", i, array[i]);


            array = new int[] { 3, 1, 2, 4, 6, 5 };
            Console.Write("排序前:");
            for (int i = 0; i < array.Length;i++ )
                Console.Write("array[{0}]={1} ", i, array[i]);
            Console.WriteLine();
           
            sord2(array);
            Console.Write("冒泡排序后:");
            for (int i = 0; i < array.Length; i++)
                Console.Write("array[{0}]={1} ", i, array[i]);
            Console.ReadKey();
        }

        //冒泡排序法
        static void sord2(int[] array)
        {
            for (int i = 0; i < array.Length; i++)
            {
                Console.WriteLine();
                Console.Write("第{0}轮排序:", i);
                for (int j = 0; j < array.Length - i - 1; j++)
                {
                    if (array[j] < array[j + 1])
                    {
                        int temp = array[j];
                        array[j] = array[j + 1];
                        array[j + 1] = temp;
                    }
                    Console.Write("array[{0}]={1} ", j, array[j]);
                }
            }
            Console.WriteLine();
           
        }

        static void sord1(int[] array)
        {
            for (int i = 0; i < array.Length; i++)
            {
                Console.WriteLine();
                Console.Write("第{0}轮排序:", i);
                for (int j = i; j < array.Length; j++)
                {
                    if (array[i] < array[j])
                    {
                        int temp = array[i];
                        array[i] = array[j];
                        array[j] = temp;
                    }
                    Console.Write("array[{0}]={1} ", j, array[j]);
                }               
            }Console.WriteLine();
        }


   
两个的运行结果是一致的,但过程是有差别的。
排序前:array[0]=3  array[1]=4  array[2]=2  array[3]=1  array[4]=6  array[5]=5

第0轮排序:array[0]=3 array[1]=3 array[2]=2 array[3]=1 array[4]=4 array[5]=5
第1轮排序:array[1]=3 array[2]=2 array[3]=1 array[4]=3 array[5]=4
第2轮排序:array[2]=2 array[3]=1 array[4]=2 array[5]=3
第3轮排序:array[3]=1 array[4]=1 array[5]=2
第4轮排序:array[4]=1 array[5]=1
第5轮排序:array[5]=1
排序后:array[0]=6  array[1]=5  array[2]=4  array[3]=3  array[4]=2  array[5]=1
排序前:array[0]=3 array[1]=1 array[2]=2 array[3]=4 array[4]=6 array[5]=5

第0轮排序:array[0]=3 array[1]=2 array[2]=4 array[3]=6 array[4]=5
第1轮排序:array[0]=3 array[1]=4 array[2]=6 array[3]=5
第2轮排序:array[0]=4 array[1]=6 array[2]=5
第3轮排序:array[0]=6 array[1]=5
第4轮排序:array[0]=6
第5轮排序:
冒泡排序后:array[0]=6 array[1]=5 array[2]=4 array[3]=3 array[4]=2 array[5]=1

[url=http://blog./ouxianzhi520]csdn个人博客[/url]
2010-04-14 09:10
qubo1982
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:367
专家分:1132
注 册:2009-3-18
得分:0 
其实就排序来说,没有什么方法是最好的,因为要关联到实际的情况,同种算法在不同情况下运算量会相差非常大
所以楼上的来一个例子来说明算法的优越性是有问题的
2010-04-14 09:23
ouxianzhi520
Rank: 8Rank: 8
来 自:重庆
等 级:蝙蝠侠
威 望:3
帖 子:245
专家分:932
注 册:2007-12-1
得分:0 
回复 9楼 qubo1982
优越性这个肯定没有什么,只是说明这冒泡排序法的一个原理而已。当然优越性应根据程序需求的实际情况来制定

[url=http://blog./ouxianzhi520]csdn个人博客[/url]
2010-04-14 09:37



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-302373-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.237025 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved