冒泡排序拓展

class Program
    {        
        static void CommonSort<T>(T[]sortArray ,Func<T,T,bool> employeeCompare)
        {
            bool swapped = true;
            do
            {
                swapped = false;
                for (int i = 0; i < sortArray.Length - 1; i++)
                {
                    if (employeeCompare(sortArray[i],sortArray[i+1]))
                    {
                        T temp = sortArray[i];
                        sortArray[i] = sortArray[i + 1];
                        sortArray[i + 1] = temp;
                        swapped = true;
                    }
                }
            } while (swapped);
        }
        static void Main(string[] args)
        {
            Employee [] a = new Employee[]
            {
                new Employee("zhangsan",2000),
                new Employee("lisi",2020),
                new Employee("wangwu",6600),
                new Employee("liuliu",5000),
            };
            CommonSort(a,Employee.Compare);

            foreach (var temp in a)
            {
                Console.WriteLine(temp.ToString());
            }
        }
    }
class Employee
    {
        public string Name { get; private set; }
        public int Salary { get; private set; }

        public Employee(string name,int salary)
        {
            this.Name = name;
            this.Salary = salary;
        }

        public static bool Compare(Employee e1,Employee e2)
        {
            if (e1.Salary > e2.Salary)
            {
                return true;
            }
            else
            {
                return false;
            }
         
        }

        public override string ToString()
        {
            return Name + " " + Salary;
        }
    }
### 回答1: 好的,以下是冒泡排序的函数模板: ```cpp template<typename T> void bubble_sort(T arr[], int n) { for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (arr[j] > arr[j + 1]) { T temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } ``` 其中,模板类型参数 `T` 表示待排序数组元素的类型,参数 `arr` 表示待排序数组的首地址,参数 `n` 表示待排序数组的长度。函数中使用两层循环,每次比较相邻的两个元素,若顺序不对则交换它们的位置,直到所有元素都被排序。 ### 回答2: 冒泡排序是一种简单直观的排序算法,它重复地走访过要排序的元素,依次比较相邻的两个元素,如果顺序不对就交换它们。 首先,我们可以编写一个函数模板来实现冒泡排序: ```cpp template<typename T> void bubbleSort(T arr[], int n) { for(int i = 0; i < n-1; i++) { for(int j = 0; j < n-i-1; j++) { if(arr[j] > arr[j+1]) { // 交换arr[j]和arr[j+1] T temp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = temp; } } } } ``` 这里的函数模板可以接受不同类型的数组进行排序。函数的参数是一个数组`arr`和数组的长度`n`。在函数内部,我们使用两个嵌套的循环来遍历数组并比较相邻元素的大小。如果前一个元素比后一个元素大,则交换它们的位置。通过这样的循环操作,最大的元素会移动到数组的末尾。然后,我们继续进行下一轮的循环,对剩下的元素进行同样的比较和交换操作,直到整个数组排序完成。 使用这个函数模板,你可以将任何类型的数组传递进去进行排序。比如,你可以这样调用函数来对一个整数数组进行排序: ```cpp int main() { int arr[] = {64, 34, 25, 12, 22, 11, 90}; int n = sizeof(arr) / sizeof(arr[0]); bubbleSort(arr, n); return 0; } ``` 通过编写这样的冒泡排序的函数模板,我们可以实现对不同类型的数组进行排序,提高了代码的复用性,使得程序更加灵活和易于拓展。 ### 回答3: 冒泡排序是一种简单但效率较低的排序算法,其思想是通过遍历数组中的相邻元素,比较它们的大小,并按照升序或降序交换位置。下面是一个用于编写冒泡排序的函数模板: ```cpp template <typename T> void bubbleSort(T arr[], int size) { for (int i = 0; i < size - 1; i++) { for (int j = 0; j < size - i - 1; j++) { // 如果当前元素大于下一个元素,则交换它们的位置 if (arr[j] > arr[j + 1]) { T temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } ``` 该函数模板使用了模板参数 T,允许对任何类型的数组进行排序。函数接受两个参数,第一个参数 arr 是待排序的数组,第二个参数 size 是数组的大小。 在冒泡排序算法中,通过两个嵌套的循环遍历数组,并比较相邻的元素。如果当前元素大于下一个元素,则交换它们的位置。这样,每一轮循环都会将最大(或最小)的元素移动到数组的末尾。 最终,数组将按照升序(或降序)排列。 使用该函数模板,可以很方便地对各种类型的数组进行冒泡排序。例如,可以将一个整型数组和一个浮点型数组传递给该函数模板,它们都可以被正确地排序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值