分别使用python和java练习冒泡排序

Posted 碎片拾零

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了分别使用python和java练习冒泡排序相关的知识,希望对你有一定的参考价值。

冒泡排序算法的运作如下:(从小到大)
 
  1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
  2. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
  3. 针对所有的元素重复以上的步骤,除了最后一个。
  4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

python:

a = [3,99,2,11,66]
n = len(a)
for i in range(n-1): #进行n-1趟
    for j in range(n-i-1) :
        if a[j] > a[j+1]:
            a[j],a[j+1] = a[j+1],a[j]
        print("第%d趟排序结果:"%(i+1),a)
print("最终排序结果:",a)

第1趟排序结果: [3, 99, 2, 11, 66]
第1趟排序结果: [3, 2, 99, 11, 66]
第1趟排序结果: [3, 2, 11, 99, 66]
第1趟排序结果: [3, 2, 11, 66, 99]
第2趟排序结果: [2, 3, 11, 66, 99]
第2趟排序结果: [2, 3, 11, 66, 99]
第2趟排序结果: [2, 3, 11, 66, 99]
第3趟排序结果: [2, 3, 11, 66, 99]
第3趟排序结果: [2, 3, 11, 66, 99]
第4趟排序结果: [2, 3, 11, 66, 99]
最终排序结果: [2, 3, 11, 66, 99]

 

java:

public class test
{
	public static void main(String[] args) 
	{
	    int i, j;
	    int[] a= {3,99,2,11,66};
	    int n = a.length;

	    for(i=0; i<n-1; i++)
	    {
	        for(j=0; j<n-i-1; j++)
	        {
	            if(a[j] > a[j+1])
	            {
	                int temp = a[j];
	                a[j] = a[j+1];
	                a[j+1]=temp;
	            }
	            System.out.print("第" + (i + 1) + "趟排序结果:");
	            for(int k=0;k<n;k++) 
			    {  
			    	System.out.print(a[k]+"\t"); 
			    }
		        System.out.print("\n"); 
	         }
	       }
	    System.out.print("最终排序结果:");
	    
	    for(i=0;i<n;i++) 
	    {  
	    	System.out.print(a[i]+"\t"); 
	    }
	}   
} 

 











以上是关于分别使用python和java练习冒泡排序的主要内容,如果未能解决你的问题,请参考以下文章

在路上---学习篇Python 数据结构和算法 -- 冒泡排序选择排序插入排序

python3----练习题(冒泡排序)

算法练习4---冒泡排序java版

过三关 Java冒泡排序选择排序插入排序小练习

Python冒泡排序

java方法的可变参数数组复制排序分类冒泡和选择排序搜索等常用方法实现