如何玩转C++运算符重载?以及Java中冒牌排序算法

  bochs调试的有些命令根据版本好像有变化,我在ubuntu下安装了bochs-2.4.6,发现和bochs-2.3.6命令出现区别,在2.3。6版本支持dump_cpu、info r等命令,在我安装的2.4.6版本中不支持这两个命令,后面在使用bochs的过程中会陆续总结一些2.4.6支持的命令,最简单的方法是通过help来获取,下面先记录一些常用的:
  
  r 查看通用寄存器
  
  sreg 查看段寄存器(IDTR被归到这里)
  
  creg 查看系统寄存器(CR0等)
  
  x 查看内存(线性地址)
  
  xp 查看内存(物理地址)
  
  info idt 查看idt信息
  
  冒泡排序(BubbleSort)的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。
  
  即首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再小于第2个数),将小数放前,大数放后,一直比较到最大数前的一对相邻数,将小数放前,大数放后,第二趟结束,在倒数第二个数中得到一个新的最大数。如此下去,直至最终完成排序。
  
  由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。
  
  int[] num = new int[]{10,30,45,23,78,56,12,18,6,2,97,34};//初始化整形数组num
  
  System.out.println("排序前数组中的数据为:");
  
  //使用foreach遍历数组输出数组中的元素
  
  for (int i : num) {
  
  System.out.println(i);
  
  }
  
  for (int i = 0; i < num.length; i++) {
  
  for (int j = 0; j < num.length-i-1; j++) {
  
  int temp = 0;//临时变量
  
  if(num[j]>num[j+1]){//如果第一个数大于第二个数,交换位置。
  
  temp = num[j];
  
  num[j]=num[j+1];
  
  num[j+1] = temp;
  
  }
  
  }
  
  }
  
  System.out.println();
  
  System.out.println("排序后数组中的数据为");
  
  for (int i : num) {
  
  System.out.println(i);
  
  }

猜你喜欢

转载自www.cnblogs.com/aquariusunny/p/12729819.html