排序与查找算法
优质
小牛编辑
151浏览
2023-12-01
排序
堆排序
#include <stdio.h>
#include <stdlib.h>
void show(int * arr, int n)
{
for (int i = 0; i < n; ++i)
{
printf("%4d", arr[i]);
}
printf("\n");
}
//01.堆排序:
// 1.用途:获取极值+极值排序
// 2.分类:小顶锥(极小值)+大顶锥(极大值)
//02.堆排序详解:
// 1.从二叉树状结构的底部开始,逐步往上层进行比较!
// 2.这里面儿的每一句代码都有含义!
//03.堆排序求极值!
void maximum(int * arr, int size)//arr:int类型的一维数组作为函数形参将会退化为(int *)类型的指针
{
for (int i = size - 1; i > 0; --i)//size-1:表示模拟从二叉树最底层最右边的一个元素开始进行遍历;i>0:表示空余数组首元素位置留作为登顶元素+(+1:只有一个元素无需极值!)
{
int child = i;//从最后一个元素-->第一个元素:进行遍历-->空余第0号元素用于登顶
int parent = i / 2;//求取父节点索引
if (i < size - 1 && arr[i] < arr[i + 1])//i<size-1:保证绝对存在右索引;arr[i]<arr[i+1]:表示左元素一定小于右元素
{
++child;//让左元素跳至到右元素
}//否则:左元素大于右元素-->推出最大子元素
if (arr[child] > arr[parent])//比较最大子元素和父元素:如果子元素大于父元素,则进行元素交换,否则保持原样!
{
int temp = arr[child];
arr[child] = arr[parent];
arr[parent] = temp;
}
}
}
//04.堆排序极值排序!
// 起始位置不变+长度不断减少
void heapSort1(int * arr, int size)
{
for (int i = size; i > 1; --i)//i>1:排除只有一个元素无需排序!
{
maximum(arr, i);
int temp = arr[0];//极值交换
arr[0] = arr[i - 1];
arr[i - 1] = temp;
}
}
//05.堆排序极值排序!
// 起始位置后移+长度不断减少
//注:要想修改数组当中的元素,就得传递数组当中元素的地址!
void heapSort2(int * arr, int size)
{
for (int i = 0; i < size; ++i)
{
maximum(arr + i, size - i);//得到一个极值,然后就进行极值位移动:分多次进行极值的求取操作!
}
}
int main01(void)
{
int arr[10] = { 10, 13, 120, 12, 30, 114, 50, 19, 60, 29 };
show(arr, 10);
//01.堆排序求极值
//maximum(arr, 10);
//show(arr, 10);
//02.堆排序极值排序!
//heapSort1(arr, 10);
heapSort2(arr, 10);
show(arr, 10);
system("pause");
}
快速排序
#include <stdio.h>
//快速排序
void QuickSort(int *arr, int left, int right)
{
//如果数组左边的索引大于或等于右边索引,说明该序列整理完毕
if (left >= right)
return;
int i = left;
int j = right;
int key = *(arr + i); //使用key来保存作为键值的数据
//本轮排序开始,当i=j时本轮排序结束,将值赋给arr[i]
while (i < j)
{
while ((i < j) && (key <= arr[j]))
j--; //不符合条件,继续向前寻找
*(arr + i) = *(arr + j);
//从前往后找一个大于当前键值的数据
while ((i < j) && (key >= arr[i]))
i++; //不符合条件,继续向后寻找
//直到i<j不成立时while循环结束,进行赋值
*(arr + j) = *(arr + i);
}
*(arr + i) = key;
QuickSort(arr, left, i - 1);
QuickSort(arr, i + 1, right);
}
//输出数组
void print(int *arr, int n)
{
for (int i = 0; i < n; i++)
printf("%d ", *(arr + i));
}
int main()
{
int arr[10] = { 3, 5, 6, 7, 2, 8, 9, 1, 0, 4 };
printf("原数组:\n");
print(arr, 10);
QuickSort(arr, 0, 9); //排序算法
printf("\n排序后的数组:\n");
print(arr, 10); //输出数组
return 0;
}
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define EN 1024
int flag = 0;
char * filePath = "E:\\Resource\\TestData\\BigDB\\Test.txt";
//数组赋值
int intArr[EN];
void initArr(int intArr[EN])
{
//time_t te;
//unsigned int seed = (unsigned int)(time(&te));
//srand(seed);
srand((unsigned int)(time(NULL)));
for (int i = 0; i < EN; ++i)
{
intArr[i] = rand() % EN + 1;
}
}
//数组显示
void showArr(int intArr[EN])
{
for (int i = 0; i < EN; ++i)
{
printf("%4d \n", intArr[i]);
}
}
//冒泡排序
void bubbleSortArr(int intArr[EN])
{
for (int i = 0; i < EN - 1; ++i)
{
for (int j = 0; j < EN - 1 - i; ++j)
{
if (intArr[j] > intArr[j + 1])
{
intArr[j] = intArr[j] ^ intArr[j + 1];
intArr[j + 1] = intArr[j] ^ intArr[j + 1];
intArr[j] = intArr[j] ^ intArr[j + 1];
}
}
}
}
//选择排序
void selectSortArr(int intArr[EN])
{
int minIndex = 0;
int minNum = 0;
for (int i = 0; i < EN - 1; ++i)
{
minIndex = i;
minNum = intArr[i];
for (int j = i + 1; j < EN; ++j)
{
if (minNum > intArr[j])
{
minIndex = j;
minNum = intArr[j];
}
}
if (i != minIndex)
{
intArr[i] = intArr[i] ^ intArr[minIndex];
intArr[minIndex] = intArr[i] ^ intArr[minIndex];
intArr[i] = intArr[i] ^ intArr[minIndex];
}
}
}
//插入排序
void insertSortArr(int intArr[EN])
{
int currentIndex = 0;
int currentValue = 0;
for (int i = 1; i < EN; ++i)
{
currentIndex = i;
currentValue = intArr[currentIndex];
while (0 < currentIndex && intArr[currentIndex - 1] > currentValue)
{
intArr[currentIndex] = intArr[currentIndex - 1];
--currentIndex;
}
intArr[currentIndex] = currentValue;
}
}
//二分查找
int binarySearch(int intArr[EN], int value)
{
int minIndex = 0;
int midIndex = 0;
int maxIndex = EN - 1;
while (minIndex <= maxIndex)
{
midIndex = (minIndex + maxIndex) / 2;
if (value == intArr[midIndex])
{
return midIndex;
}
else if (value < intArr[midIndex])
{
maxIndex = midIndex - 1;
}
else
{
minIndex = midIndex + 1;
}
}
return -1;
}
//拉格朗日查找
int lagrangeSearch(int intArr[EN], int value)
{
int minIndex = 0;
int ratioIndex = 0;
int maxIndex = EN - 1;
while (minIndex <= maxIndex)
{
//midIndex = minIndex + (maxIndex - minIndex) / 2;
ratioIndex = minIndex + (maxIndex - minIndex)*(value - intArr[minIndex]) / (intArr[maxIndex] - intArr[minIndex]);
if (value == intArr[ratioIndex])
{
return ratioIndex;
}
else if (value < intArr[ratioIndex])
{
maxIndex = ratioIndex - 1;
}
else
{
minIndex = ratioIndex + 1;
}
}
return -1;
}
int main01(void)
{
initArr(intArr);
showArr(intArr);
insertSortArr(intArr);
printf("binSearch Index = %d \n", binarySearch(intArr, 880));
printf("lagrangeSearch index = %d \n", lagrangeSearch(intArr, 880));
system("pause");
}
查找
二分查找
void ShowArray(int a[], int n)
{
for (int i = 0; i < n; i++)
{
printf("%d,", a[i]);
}
printf("\n");
}
void Sort(int a[], int n) // 冒泡排序
{
for (int i = 0; i < n - 1; i++)
{
for (int j = 0; j < n - 1 - i; j++)
{
if (a[j]>a[j+1])
{
int temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}
}
//num为所要查找的数据,返回数组下标
int SearchFor(int a[], int n, int num)
{
for (int low = 0, high = n - 1, mid = (low + high) / 2;
low <= high; mid=(low+high)/2)
{
printf("\n开始查找%d,%d,%d", low, high, mid);
if (a[mid] == num)
{
return mid;
}
else if (a[mid]>num)
{
high = mid - 1;
}
else
{
low = mid + 1;
}
}
}
int BinarySearch(int a[], int n, int num)
{
int low = 0;
int high = n - 1;
int mid = (low + high) / 2;
while (low <= high)
{
printf("\n开始查找%d,%d,%d", low, high, mid);
if (a[mid] == num)
{
return mid;
}
else if (a[mid]>num)
{
high = mid - 1;
mid = (low + high) / 2;
}
else
{
low = mid + 1;
mid = (low + high) / 2;
}
}
}
void main()
{
int a[50] = { 0 };
time_t ts;
srand((unsigned int)time(&ts));//随机数种子
for (int i = 0; i < 50; i++)
{
a[i] = rand() % 100;
//printf("%d,", a[i]);
}
Sort(a, 50);
ShowArray(a, 50);
int num;
printf("plesae input your find num:");
scanf("%d", &num); //扫描数据接收输入
//int ret = SearchFor(a, 50, num);
int ret = BinarySearch(a, 50, num);
if (ret == -1)
{
printf("not find\n");
}
else
{
printf("find [%d]\n", a[ret]);
}
system("pause");
}