学习笔记-冒泡排序

学习笔记-冒泡排序

原理:两两比较,如果前一个数大于后一个数就交换次序,直到最大的数排到最后。

示例:

思路:

确定共要比较几轮:一共有7个数字,第一轮比较下来只剩6个数字需要比较,第二轮剩5个,第三轮剩4个,第四轮剩3个,第五轮剩2个,第六轮剩1个,结              束。所以一共要进行六轮,即要进行n-1轮。

确定每一轮中的比较次数:第一轮中,有7个数,两两比较需要6次;第二轮中,有6个数需要比较,所以需要比较5次,以此类推

代码:


import java.util.Arrays;

public class BubbleSort {
	public static void main(String[] args) {
		int[] arr = new int[] {2,3,5,1,8,7,6};
		bubblesort(arr);
		System.out.println(Arrays.toString(arr));
	}
	
	public static void bubblesort(int[] arr) {
		/*
		 * 两两比较,如果前一个大于后一个就交换, 一共进行n-1轮
		 * 第一轮将最大的数放到最后,依次类推 已排好的数不需要比较 
		 */
		for(int i=0;i<arr.length-1;i++) {
			for(int j=0;j<arr.length-1-i;j++) {
				if(arr[j] > arr[j+1]) {
				int temp = arr[j];
				arr[j] = arr[j+1];
				arr[j+1] = temp;
				}
			}
		}
	}

}

       

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
汇编语言可以在ARM架构中实现冒泡排序算法。首先,我们可以使用汇编语言编写一个函数来实现冒泡排序。这个函数可以接受一个字符数组和数组的长度作为参数。然后,我们可以通过使用汇编指令来执行冒泡排序的步骤。 首先,我们可以使用str指令来交换数组中相邻的元素。为了实现冒泡排序,我们需要一个内部循环来比较和交换相邻的元素,直到数组被完全排序。我们可以使用cmp指令来控制内部循环的次数。然后,我们可以使用bne指令来跳转到内部循环的开始,直到数组被完全排序。 同时,我们还需要一个外部循环来控制整个排序的次数。我们可以使用cmp指令来控制外部循环的次数。然后,我们可以使用bne指令来跳转到外部循环的开始,直到数组被完全排序。 为了实现这个汇编程序,我们可以参考提供的C语言与汇编语言混合使用的代码。通过仿照C语言的代码流程,我们可以分步骤编写汇编代码。首先,我们需要编写交换数据的汇编代码。然后,我们需要考虑内部循环的代码,以及外部循环的代码。 总之,使用ARM汇编语言实现冒泡排序需要编写交换数据的汇编代码,并通过内部循环和外部循环来实现排序算法。你可以参考提供的C语言与汇编语言混合使用的代码,并根据这个代码来编写你的汇编程序。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【ARM学习笔记】C与汇编混合编程—冒泡排序算法](https://blog.csdn.net/qq_43401552/article/details/105686643)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [ARM C语言调用汇编函数 实现冒泡排序](https://blog.csdn.net/ZHJ123CSDN/article/details/105511944)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值