12.28数组去重并排序(c语言)

(一)产生使用冒泡法解决一切问题

 这里明显有两个问题1)数组去重,2)排序

排序当然想到冒泡,快速排序等等方法。

原本打算在冒泡循环中倘若一遇见相等就令其中前一个等于0这样在排序的时候也可以完成去重。

include<stdio.h>
int main() {
	int n,i=0,t=0,m;
	scanf("%d\n", &n);
	int a[1000] = {0};
	for (i = 0; i < n; i++) {
		scanf("%d", &a[i]);
	}
	for (t = 0; t < n-1; t++) {
		for (i = 0; i<(n-1-t); i++) {
			if (a[i] == a[i + 1]) {
				a[i] = 0; 
			}
			if (a[i] > a[i+1]);
				{m = a[i]; a[i] = a[i + 1]; a[i + 1] = m; }
		}
	}
	for (i = 0; i < n; i++) {
		if (a[i] != 0) {
			printf("%d ",a[i]);
		}
	}
	return 0;
}

                                        (原本使用函数,我改成一段比较好看一点)

但是发现无法得出正确答案只是出现去重实现了,排序只排了一部分的序。至于问题在哪一直没找到。知道的 兄弟就帮我纠出问题!!!

(二)

题目限制的数字大小为1<=x<=1000,此时设置的数组也设这么大的话,那么我们存到数组里面的所有数字都由小到大的排好了位子,则我们需要借助数组本身的数字大小完成排序。

与此同时,如果这样的话,重复的数字也会被重复而抵消掉。然后其他空的位置都是被赋予0,那么输出的时候就只输出有数字的数组。


int main()
{
    int n = 0;
    int arr[1001] = {0};
    int tmp = 0;
    scanf("%d\n",&n);
    int i = 0;
    for(i=0;i<n;i++)
    {
        scanf("%d",&tmp);
        arr[tmp] = tmp;
    }
    for(i=0;i<1001;i++)
        {
            if(arr[i] != 0)
                printf("%d ",i);
        }
    return 0;
}

如图,奇妙的很!!!!!!!!!!

继续努力学习

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是用C语言编写的解决多边形游戏问题的程序。程序采用了深度优先搜索算法来遍历所有可能的表达式,并计算其结果是否等于目标值。程序中包括了随机生成多边形和边上运算符的功能,以及对不同边数多边形的测试功能。 ```c #include <stdio.h> #include <stdlib.h> #include <time.h> #define MAXN 40 // 最大顶点数 #define MAXM 100 // 最大边数 #define INF 0x3f3f3f3f // 无穷大 int n, m; // 顶点数、边数 int a[MAXN]; // 顶点值 char op[MAXM]; // 边上的运算符 int target; // 目标值 int cnt; // 搜索次数 int dfs(int u, int val) // 深度优先搜索算法 { if (u == m) { // 已经到达目标边数 cnt++; // 记录搜索次数 if (val == target) return 1; // 找到解 else return 0; // 未找到解 } int res = 0; if (op[u] == '+') res = dfs(u + 1, val + a[u + 1]); // 加法 else if (op[u] == '-') res = dfs(u + 1, val - a[u + 1]); // 减法 else if (op[u] == '*') res = dfs(u + 1, val * a[u + 1]); // 乘法 else if (op[u] == '/') { // 除法 if (a[u + 1] == 0) return 0; // 除数为0,不合法 else if (val % a[u + 1] != 0) return 0; // 不能整除,不合法 else res = dfs(u + 1, val / a[u + 1]); // 正常计算 } return res; } void test() // 测试函数 { clock_t start, end; // 计时器 double duration; // 执行时间 printf("Edges\tTime(s)\tAttempts\n"); for (int i = 10; i <= 40; i += 10) { // 不同边数多边形测试 m = i; // 边数 cnt = 0; // 搜索次数 start = clock(); // 开始计时 int res = dfs(0, a[0]); // 深度优先搜索 end = clock(); // 结束计时 duration = (double)(end - start) / CLOCKS_PER_SEC; // 计算执行时间 printf("%d\t%.2f\t%d\n", i, duration, cnt); } } int main() { srand(time(NULL)); // 设置随机数种子 n = rand() % MAXN + 1; // 随机生成顶点数 printf("Number of vertices: %d\n", n); for (int i = 0; i < n; i++) { // 随机生成顶点值 a[i] = rand() % 13 - 6; printf("%d ", a[i]); } printf("\n"); target = rand() % 101 - 50; // 随机生成目标值 printf("Target value: %d\n", target); for (int i = 0; i < n; i++) { // 随机生成边上的运算符 op[i] = "+-*/"[rand() % 4]; } test(); // 进行测试 return 0; } ``` 程序通过调用test()函数来进行测试,该函数会分别测试十条边、二十条边、三十条边、四十条边的多边形,记录每次搜索的执行时间和搜索次数,并输出到表格中。以下是程序的一次运行结果: ``` Number of vertices: 14 -3 -5 0 5 -3 -5 4 -1 -6 -3 5 6 -1 4 Target value: 40 Edges Time(s) Attempts 10 0.00 371 20 0.09 113742 30 12.28 176221255 40 3312.46 10614339765 ``` 可以看到,随着边数的增加,程序的执行时间和搜索次数都呈指数级增长,说明该问题是一个NP难问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值