1.选择排序: //改进后的选择排序,减少交换的次数 public static void sortSelect(int arr[]) { //用于存放最小数的下标 int s; for (int i = 0; i < arr.length; i++) { s = i; for (int j = i + 1; j < arr.length; j++) { if (arr[s] > arr[j]) { //记录最小值的下标值 s = j; } } //如果最小数的下标值改变,则交换 if…
#include <stdio.h> int main() { ], t; int i, j, max; printf("请输入10个数:\n"); ; i <= ; i=i+) scanf_s("%d", a+i); ; j >=; j = j-) { max = j; ; i <=j; i = i + ) { if (a[max] <= *(a+i)) max = i; if (max != j) { t = a[max];…
最开始的代码 我采用的是我原来进行快速排序所用的方法,一直做不出来. 为什么我会采用原来快速排序的方法?因为我的记忆中好像就是这样的,因此我根据记忆中的快速排序在进行改变,然而,却无法真正的写出双冒泡排序算法,所以,真正的学习是,即使随着时间的流逝,你已经不记得某些东西了,但是,你可以凭借理解在重新写出来. public static void sort(int[] num, int l, int r) { int i = l; int j = l + 1; int key = num[l];…
public class NumberSort {/***读进9个数:*构建成一个int型数组:*顺序排好:**/public static void main(String args[]) {int a[] = new int[args.length];if (args.length == 0) {System.out.println("Usage: Please input some numbers in command line parameters. 0");System.ex…