编程实现插入排序函数。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