原理:比较两个相邻的元素,将值大的元素交换至右端。
思路:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复第一趟步骤,直至全部排序完成。
举例说明:要排序数组:int[]arr={6,3,8,2,9,1};
第一趟排序:
第一次排序:6和3比较,6大于3,交换位置:368291
第二次排序:6和8比较,6小于8,不交换位置:368291
第三次排序:8和2比较,8大于2,交换位置:362891
第四次排序:8和9比较,8小于9,不交换位置:362891
第五次排序:9和1比较:9大于1,交换位置:362819
第一趟总共进行了5次比较, 排序结果: 362819
---------------------------------------------------------------------
第二趟排序:
第一次排序:3和6比较,3小于6,不交换位置:362819
第二次排序:6和2比较,6大于2,交换位置:326819
第三次排序:6和8比较,6大于8,不交换位置:326819
第四次排序:8和1比较,8大于1,交换位置:326189
第二趟总共进行了4次比较, 排序结果: 326189
---------------------------------------------------------------------
第三趟排序:
第一次排序:3和2比较,3大于2,交换位置:236189
第二次排序:3和6比较,3小于6,不交换位置:236189
第三次排序:6和1比较,6大于1,交换位置:231689
第二趟总共进行了3次比较, 排序结果: 231689
---------------------------------------------------------------------
第四趟排序:
kmhx.b2b168.com
kmhuaxi.51sole.com
http://www.wenbing.cn/kmhx/
第一次排序:2和3比较,2小于3,不交换位置:231689
第二次排序:3和1比较,3大于1,交换位置:213689
第二趟总共进行了2次比较, 排序结果: 213689
---------------------------------------------------------------------
第五趟排序:
第一次排序:2和1比较,2大于1,交换位置:123689
第二趟总共进行了1次比较, 排序结果: 123689
---------------------------------------------------------------------
最终结果:123689
---------------------------------------------------------------------
由此可见:N个数字要排序完成,总共进行N-1趟排序,每i趟的排序次数为(N-i)次,所以可以用双重循环语句,外层控制循环多少趟,内层控制每一趟的循环次数