四种排序:冒泡,选择,插入,二分(折半插入) public class Test{ // public static void main(String[] args) { // Test t=new Test(); public static void bubbleSort(int[] source){ // 交换类排序思想: 两两比较待排序的关键字,发现记录相反则交换,直到没有反序的记录. for(int i = source.length - 1; i > 0; i--){ for(int…
题目:首先需要实现一个函数:两个字符串大小比较(不得使用c#/java系统函数)的自定义函数:之后对一个字符串数据进行按升序排序(在排序过程中使用字符串大小比较时,使用自定义的字符串大小比较函数). 以下是对一个字符串数据进行按升序排序我个人想到的实现方案: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Demo { class Program { /…
本文中的方法旨在解决通用的问题,非常注重效率的地方,还应该针对具体的类去写排序方法. 废话不多说,直接上代码 具体使用场景: 要排序的类 1 public class bb 2 { 3 public aa a { get; set; } 4 } 5 6 public class aa 7 { 8 public string index { get; set; } 9 public string name { get; set; } 10 11 public aa(string index, st…
选择类排序包括: (1) 简单选择排序 (2)树形选择排序 (3)堆排序 简单选择排序: [算法思想]:在第 i 趟简单选择排序中,从第 i 个记录开始,通过 n - i 次关键字比较,从 n - i + 1 个记录中选出关键字最小的记录,并和第 i 个记录进行交换 时间复杂度:O(n^2) //此函数中a[0]不用,即对 a[1] ~ a[length-1] 排序: //如果对a[0]~a[length-1]排序,将 for 循环中的 i = 1 改为 i = 0 即可,注意输出 void…
1.直接插入排序算法 源码: package com.DiYiZhang;/* 插入排序算法 * 如下进行的是插入,排序算法*/ public class InsertionSort { public static void insertionSort(int[] a) { int tmp; for (int i = 1; i < a.length; i++) { for (int j = i; j >0; j--) { …
首先先介绍一下平时最常用的几种排序方法. 第一种:实体类实现IComparable接口,而且必须实现CompareTo方法 实体类定义如下: class Info:IComparable { public int Id { get; set; } public string Name { get; set; } public int CompareTo(object obj) { int result; try { Info info = obj as Info; if (this.Id > i…