分别使用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");
	    }
	}
} 

原文地址:https://www.cnblogs.com/feiyueNotes/p/8232754.html

时间: 2024-10-05 05:01:16

分别使用python和java练习冒泡排序的相关文章

java实现冒泡排序

<span style="font-size:18px;">package two.java.test; /** * 冒泡排序最基本的学c语言的时候就先接触的是冒泡排序 * 也有叫起泡排序的不过我还是喜欢叫冒泡排序 */ public class BubbleSort{ public static void main(String args[ ]){ int [ ]intArray={12,11,45,6,8,43,40,57,3,20}; System.out.print

Golang、Php、Python、Java基于Thrift0.9.1实现跨语言调用

目录: 一.什么是Thrift? 1) Thrift内部框架一瞥 2) 支持的数据传输格式.数据传输方式和服务模型 3) Thrift IDL 二.Thrift的官方网站在哪里? 三.在哪里下载?需要哪些组件的支持? 四.如何安装? 五.Golang.Java.Python.PHP之间通过Thrift实现跨语言调用 1) Golang 客户端和服务端的实现及交互 2) python 客户端的实现与golang 服务端的交互 3) php 客户端的实现与golang 服务端的交互 4) java

python调用java

这么个标题多少有点蛋疼的感觉,两个都是互联网时代的语言,学习成本和执行效率也差不多,之所以会产生这种需求,多半是想在python中引用java的类,例如安卓和hadoop的生态圈,基本是java代码的天下,虽然python大数据有不错的接口,但直接调用java的需求总是有的.这个目前已经有解决方案,例如jython,采用了java编写的python的解释器,在java虚拟机上面运行了python虚拟机,想想都悲催,两个慢解释型语言的结合jython速度慢来自于基因. 还有一种方案就是使用c做桥接

六种流行的语言---C、C++、python、Java、php、C#比较[转]

语言大餐 回归正题,本文是六种语言连接mysql数据库的代码展示,在LZ尝试的过程中,无论是语言环境搭建.mysql依赖库的导入还是代码的风格,各种语言都各有千秋.接下来,我们就让这些语言一一登场吧. Java(最具噱头的语言) Java给新人的印象应该是入门简单.代码优雅.活跃度高.跨平台.开源大家庭等等,实在是当之无愧的明星语言,而且是偶像派的.不过可惜的是,偶像派明星很容易被干掉.Java语言是LZ赖以生存的语言,因此LZ不希望做个偶像派,只能奋起直追,争取做实力派的Javaer. 说起这

java之冒泡排序

//冒泡排序(Bubble Sorting)的基本思想是:通过对待排序序列从后向前(从下标较大的元素开始),依次比较相邻元素的排序码,若发现逆序则交换,使排序码较小的元素逐渐从后部移向前部(从下标较大的单元移向下标较小的单元),就象水底下的气泡一样逐渐向上冒. public static void main(String[] args) {      int arr[]={1,6,0,-1,9,-100,90};      int temp=0;      //排序      //外层循环,可以

51CTO下载-python调用java.docx

链接: http://blog.csdn.net/jobjava/article/details/7280798 python调用Java: JPype使用介绍 Python 作为一种灵活的软件开发语言在当今被广泛使用.在软件开发过程中,有时需要在 Python 项目中利用既有的 Java 代码,已达到节省时间和开发成本的目的.因此,找到一个 Python 代码调用 Java 代码的桥梁是非常有意义的. JPype 就是这样的一个工具,利用它可以使 Python 程序方便的调用 Java 代码,

简明Python教程命令行地址簿的Python与Java实现

最近读完了简明Python教程(A Byte of Python),在此书的最后作者建议读者实现一个命令行Python程序: "在这个程序中,你可以添加.修改.删除和搜索你的联系人(朋友.家人和同事等等)以及它们的信息(诸如电子邮件地址和/或电话号码).这些详细信息应该被保存下来以便以后提取." 现在特地来交作业,同时对作者Swaroop, C. H.和译者沈洁元表示感谢!谢谢两位无私的奉献:) 操作系统windows7,Python版本2.7.5. #address.py #首先我们

python调用Java代码,完毕JBPM工作流application

1.缘由 有一庞大Python django webproject,要引入工作流引擎,像OA一样.方便的流程控制与管理.Python或django关于工作流的开源插件,稀少,并且弱爆了,终于选用java的开源框架JBPM.为了使Pythonproject整合Java框架,尝试过jbpm-console提供的 REST, 以失败告终,终于选用Python 直接调用Java代码.操作JBPM. 1.1pythonprojectREST与JBPM Workbench交互 失败 REST URL格式 h

计算机相关视频资料分享(C/C++、python、java/Android、linux、算法、数据库等)

相关视频学习资料(C/C++.python.java/Android.linux.算法.数据库等)仅用于学习交流,不要用于商业目的. 1.C/C++ 系列 链接:http://pan.baidu.com/s/1gdvKXIN 密码:lglp 2.python系列 链接:http://pan.baidu.com/s/1eQzl4aQ 密码:5931 3.linux 系列: 链接:http://pan.baidu.com/s/1hq7UiDu 密码:yk7r 4.java 和Android 系列 链