Compare commits

..

2 Commits

3 changed files with 138 additions and 0 deletions
+41
View File
@@ -0,0 +1,41 @@
#include <stdio.h>
int main()
{
int a[100], i, j, t, n;
scanf("%d", &n); // 输入一个数,表示接下来有 n 个数
for (i = 1; i <= n; i++)
{
scanf("%d", &a[i]);
}
// 冒泡排序的核心部分
for (i = 1; i <= n - 1; i++) // n 个数排序,只用进行 n - 1 趟
{
// 从第 1 位开始比较直到最后一个尚未归位的数,想一想为什么到 n - i 就可以了
for (j = 1; j <= n - i; j++)
{
if (a[j] < a[j + 1]) // 比较大小并交换
{
// t = a[j];
// a[j] = a[j + 1];
// a[j + 1] = t;
// 位运算交换
a[j] ^= a[j + 1];
a[j + 1] ^= a[j];
a[j] ^= a[j + 1];
}
}
}
for (i = 1; i <= n; i++) // 输出结果
printf("%d ", a[i]);
getchar();
getchar();
return 0;
return 0;
}
+39
View File
@@ -0,0 +1,39 @@
#include <stdio.h>
struct student
{
char name[21]; // 21 个字节
int score;
};
int main()
{
struct student a[100], t;
int i, j, n;
scanf("%d", &n);
for (int i = 1; i <= n; i++)
{
scanf("%s %d", a[i].name, &a[i].score);
}
for (i = 1; i <= n - 1; i++)
{
for (j = 1; j <= n - i; j++)
{
if (a[j].score < a[j + 1].score)
{
t = a[j];
a[j] = a[j + 1];
a[j + 1] = t;
}
}
}
printf("\033[2J");
for (int i = 1; i <= n; i++)
printf("%s\n", a[i].name);
getchar();
getchar();
return 0;
}
+58
View File
@@ -0,0 +1,58 @@
// 快速排序
// 平均时间复杂度: O(NlogN) - 最差时间复杂度: O(N^2)
#include <stdio.h>
int a[101], n; // 定义全局变量,这两个变量需要在子函数中使用
void quicksort(int left, int right)
{
int i, j, t, temp;
if (left > right)
return;
temp = a[left]; // temp 中存的就是基准数
i = left;
j = right;
while (i != j)
{
// 顺序很重要,要先从右往左找
while (a[j] >= temp && i < j)
j--;
// 在从左往右找
while (a[i] <= temp && i < j)
i++;
if (i < j)
{
t = a[i];
a[i] = a[j];
a[j] = t;
}
}
// 最终将基准数归位 (交换基准数和 i 位置当前值)
a[left] = a[i];
a[i] = temp; // temp 在上面有定义
quicksort(left, i - 1); // 继续处理左边的,这里是一个递归的过程
quicksort(i + 1, right); // 继续处理右边的
return;
}
int main()
{
int i, j;
// 读入数据
scanf("%d", &n);
for (i = 1; i <= n; i++)
scanf("%d", &a[i]);
quicksort(1, n); // 快速排序调用
// 输出排序后的结果
for (i = 1; i <= n; i++)
printf("%d ", a[i]);
printf("\n");
return 0;
}