6-4 插入排序 (10分)

编程实现插入排序函数。void insertionSort(int arr[], int n);。其中arr存放待排序的数据,n为数组长度(1≤n≤1000)。

函数接口定义如下:

/* 对长度为n的数组arr执行插入排序 */
void insertionSort(int arr[], int n);

请实现insertionSort函数,使排序后的数据从小到大排列。

裁判测试程序样例:

#include <stdio.h>

#define N 1000
int arr[N];

/* 对长度为n的数组arr执行插入排序 */
void insertionSort(int arr[], int n);

/* 打印长度为n的数组arr */
void printArray(int arr[], int n);

int main() {
    int n, i;
    scanf("%d", &n);
    for (i = 0; i < n; ++i) {
        scanf("%d", &arr[i]);
    }
    insertionSort(arr, n);
    printArray(arr, n);
    return 0;
}
/* 打印长度为n的数组arr */
void printArray(int arr[], int n) {
    int i;
    for (i = 0; i < n; i++) {
        printf("%d", arr[i]);
        if (i < n - 1)  /* 下标0..n-2每个元素后面有个空格 */
            printf(" ");/*下标n-1,也就是最后一个元素后面没有空格*/
    }
    printf("\n");/* 一行打印完后换行 */
}
/* 你的代码将嵌在这里 */

输入样例:

10

1 19 9 11 4 3 5 8 10 6

输出样例:

1 3 4 5 6 8 9 10 11 19

由于只允许用C语言进行答题,不能用algorithm头文件的sort来偷鸡,但是这不代表我大C就没有一个排序函数了啊(狗头)

作业偷鸡第一人

#include<stdlib.h>
int cmp_int(const void* _a, const void* _b)
{
    int* a = (int*)_a;   
    int* b = (int*)_b;
    return *a - *b;
}
void insertionSort(int arr[], int n) {
    qsort(arr, n,sizeof(int),cmp_int);
}

C语言stdlib头文件下自带排序函数,可以对数组进行排序,这就是qsort函数(全称quicksort)。它是ANSI C标准中提供的,其声明在stdlib.h文件中,是根据二分法写的,其时间复杂度为n*log(n)。

void qsort(void* base,size_t num,size_t width,int(__cdecl*compare)(const void*,const void*));

其中参数
1 待排序数组,排序之后的结果仍放在这个数组中
2 数组中待排序元素数量
3 各元素的占用空间大小(单位为字节)
4 指向函数的指针,用于确定排序的顺序(需要用户自定义一个比较函数)

因为标准C不支持函数重载,因此参数都需要写上,其中的顺序规则函数比较常见的有:

对int型数组排序

int num[100];
int cmp_int(const void* _a , const void* _b) 
{
    int* a = (int*)_a;  
    int* b = (int*)_b;
    return *a - *b;  
}

对char型数组排序(同int类型)

char word[100];
int cmp_char(const void* _a , const void* _b) 
{
    char* a = (char*)_a;    
    char* b = (char*)_b;
    return *a - *b;  
}

对double型数组排序

double in[100];
int cmp_double(const void* _a , const void* _b) 
{
    double* a = (double*)_a;   
    double* b = (double*)_b;
    return *a > *b ? 1 : -1;   
}
  • 在对浮点或者double型的一定要用三目运算符,因为要是使用像整型那样相减的话,如果是两个很接近的数则可能返回一个很小的小数(大于-1,小于1),而cmp的返回值是int型,因此会将这个小数返回0,系统认为是相等,失去了本来存在的大小关系

对字符串进行排序

char word[100][10];
int cmp_string(const void* _a , const void* _b)  //参数格式固定
{
    char* a = (char*)_a;  //强制类型转换
    char* b = (char*)_b;
    return strcmp(a,b);
}

qsort(word,100,sizeof(word[0]),cmp_string); 

qsort部分出处 https://blog.csdn.net/zhao888789/article/details/79186619

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值