【2018统考真题】给定一个含n(n≥1)个整数的数组,请设计一个在时间上尽可能高 效的算法,找出数组中未出现的最小正整数。

【2018统考真题】给定一个含n(n≥1)个整数的数组,请设计一个在时间上尽可能高

效的算法,找出数组中未出现的最小正整数。例如,数组{-5,3,2,3}中未出现的最小正

整数是1;数组{1,2,3}中未出现的最小正整数是4。

代码思路:

题目让你找未出现的最小正数,你就从1往下循环,用当前循环的数去看看数组里面有没有,也就是查找,我这里就用最简单暴力算法,你可以用其他一些高效的查找算法,比如快排啥的。

c 复制代码
int find_minN(int A[],int len) {
	int i = 1;
	int j = 0;
	int flag = 0;//标记位,0表示数组里面没有当前的i,1表示有
	while(i){
		flag = 0;
		for (j = 0;j < len;j++) {
			if (i == A[j]) {
				flag = 1;
				continue;
			}
		}
		if (flag == 0) {//找到最小正整数
			return i;
		}
		i++;
		if (i > len) {
			return i;
		}
	}
}
int main() {
	int A[4] = { -5,3,2,3 };//几个测试用例
	int B[3] = { 1,2,3 };
	int C[10] = { 1,5,2,6 };
	int D[7] = { 2,3,1,5,6,4 };
	int m_A = find_minN(A,4);
	printf("A中未出现的最小正整数为%d\n", m_A);

	int m_B = find_minN(B,3);
	printf("B中未出现的最小正整数为%d\n", m_B);

	int m_C = find_minN(C, 4);
	printf("C中未出现的最小正整数为%d\n", m_C);

	int m_D = find_minN(D, 6);
	printf("D中未出现的最小正整数为%d\n", m_D);
	return 0;
}
相关推荐
-qOVOp-19 分钟前
408第一季 - 数据结构 - 图II
数据结构
凌辰揽月19 分钟前
Web后端基础(基础知识)
java·开发语言·前端·数据库·学习·算法
-qOVOp-19 分钟前
408第一季 - 数据结构 - 树与二叉树III
数据结构
lifallen25 分钟前
深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
java·开发语言·数据结构·算法·排序算法
jingfeng51425 分钟前
数据结构排序
数据结构·算法·排序算法
能工智人小辰1 小时前
Codeforces Round 509 (Div. 2) C. Coffee Break
c语言·c++·算法
kingmax542120081 小时前
CCF GESP202503 Grade4-B4263 [GESP202503 四级] 荒地开垦
数据结构·算法
岁忧1 小时前
LeetCode 高频 SQL 50 题(基础版)之 【高级字符串函数 / 正则表达式 / 子句】· 上
sql·算法·leetcode
eachin_z2 小时前
力扣刷题(第四十九天)
算法·leetcode·职场和发展
闻缺陷则喜何志丹2 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点