Compare commits
4 Commits
4412ac3a37
..
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 4941b97bba | |||
| 5f5d157621 | |||
| b19828f9e4 | |||
| 6e5f30728b |
+36
@@ -0,0 +1,36 @@
|
|||||||
|
# ---> C++
|
||||||
|
# Prerequisites
|
||||||
|
*.d
|
||||||
|
|
||||||
|
# Compiled Object files
|
||||||
|
*.slo
|
||||||
|
*.lo
|
||||||
|
*.o
|
||||||
|
*.obj
|
||||||
|
|
||||||
|
# Precompiled Headers
|
||||||
|
*.gch
|
||||||
|
*.pch
|
||||||
|
|
||||||
|
# Compiled Dynamic libraries
|
||||||
|
*.so
|
||||||
|
*.dylib
|
||||||
|
*.dll
|
||||||
|
|
||||||
|
# Fortran module files
|
||||||
|
*.mod
|
||||||
|
*.smod
|
||||||
|
|
||||||
|
# Compiled Static libraries
|
||||||
|
*.lai
|
||||||
|
*.la
|
||||||
|
*.a
|
||||||
|
*.lib
|
||||||
|
|
||||||
|
# Executables
|
||||||
|
*.exe
|
||||||
|
*.out
|
||||||
|
*.app
|
||||||
|
|
||||||
|
# 自定义忽略
|
||||||
|
test
|
||||||
@@ -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;
|
||||||
|
}
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
// 简化桶排序桶排序
|
||||||
|
// 啊哈算法 P4-5
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int a[11], i, j, t;
|
||||||
|
for (i = 0; i <= 10; i++)
|
||||||
|
a[i] = 0; // 初始化为0
|
||||||
|
|
||||||
|
for (i = 1; i <= 5; i++)
|
||||||
|
{
|
||||||
|
scanf("%d", &t); // 把每一个数读入到变量 t 中
|
||||||
|
a[t]++; // 进行计数
|
||||||
|
}
|
||||||
|
|
||||||
|
// 从小到大排序
|
||||||
|
// for (i = 0; i <= 10; i++) // 依次判断 a[0]~a[10]
|
||||||
|
// 从大到小排序
|
||||||
|
for (i = 10; i >= 0; i--)
|
||||||
|
for (j = 1; j <= a[i]; j++) // 出现了几次就打印几次
|
||||||
|
printf("%d ", i);
|
||||||
|
|
||||||
|
/* 用于Windows
|
||||||
|
getchar();getchar(); // 用来暂停程序,以便查看程序输出的内容
|
||||||
|
// 也可以用 system("pause"); 等来替代
|
||||||
|
*/
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
@@ -0,0 +1,30 @@
|
|||||||
|
// 简化桶排序
|
||||||
|
// 啊哈算法 P6
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int book[1001], i, j, t, n;
|
||||||
|
|
||||||
|
for (i = 0; i <= 1000; i++)
|
||||||
|
book[i] = 0;
|
||||||
|
|
||||||
|
printf("请输入要排序的数的个数: ");
|
||||||
|
scanf("%d", &n); // 输入一个数 n,表示接下来有 n 个数
|
||||||
|
printf("请输入 %d 个数,使用空格隔开: \n", n);
|
||||||
|
for (i = 1; i <= n; i++) // 循环读入 n 个数,并进行桶排序
|
||||||
|
{
|
||||||
|
scanf("%d", &t); // 把每一个数读入到变量 t 中
|
||||||
|
book[t]++; // 进行计数,对编号为 t 的桶放一个小旗子
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 1000; i >= 0; i--) // 依次判断编号 1000~0 的桶
|
||||||
|
for (j = 1; j <= book[i]; j++) // 出现了几次就打印几次
|
||||||
|
printf("%d ", i); // 打印编号
|
||||||
|
|
||||||
|
// 用来暂停程序,以便查看程序输出的内容
|
||||||
|
// getchar();
|
||||||
|
// getchar();
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
@@ -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;
|
||||||
|
}
|
||||||
@@ -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;
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user