OI Wiki—枚举

ops/2025/1/16 0:50:55/

 //新生训练,搬运整理

简介

枚举(英语:Enumerate)是基于已有知识来猜测答案的问题求解策略。

枚举的思想是不断地猜测,从可能的集合中一一尝试,然后再判断题目的条件是否成立。

要点

给出解空间

建立简洁的数学模型。

枚举的时候要想清楚:可能的情况是什么?要枚举哪些要素?

减少枚举的空间

枚举的范围是什么?是所有的内容都需要枚举吗?

在用枚举法解决问题的时候,一定要想清楚这两件事,否则会带来不必要的时间开销。

选择合适的枚举顺序

根据题目判断。比如例题中要求的是最大的符合条件的素数,那自然是从大到小枚举比较合适。

例题

以下是一个使用枚举解题与优化枚举范围的例子。

Q:一个数组中的数互不相同,求其中和为 0 的数对的个数。

A1:枚举两个数

for (int i = 0; i < n; ++i)for (int j = 0; j < n; ++j)if (a[i] + a[j] == 0) ++ans;

对于A1:

来看看枚举的范围如何优化。由于题中没要求数对是有序的,答案就是有序的情况的两倍(考虑如果 (a, b) 是答案,那么 (b, a) 也是答案)。对于这种情况,只需统计人为要求有顺序之后的答案,最后再乘上 2 就好了。

A2:不妨要求第一个数要出现在靠前的位置

for (int i = 0; i < n; ++i)for (int j = 0; j < i; ++j)if (a[i] + a[j] == 0) ++ans;

不难发现这里已经减少了 j 的枚举范围,减少了这段代码的时间开销。

对于A2:

我们可以在此之上进一步优化。

两个数是否都一定要枚举出来呢?枚举其中一个数之后,题目的条件已经确定了其他的要素(另一个数)的条件,如果能找到一种方法直接判断题目要求的那个数是否存在,就可以省掉枚举后一个数的时间了。较为进阶地,在数据范围允许的情况下,我们可以使用桶1记录遍历过的数。

//要求 a 数组中的数2的绝对值都小于 MAXN
bool met[MAXN * 2];
// 初始化 met 数组为 0
memset(met, 0, sizeof(met));
for (int i = 0; i < n; ++i)
{if (met[MAXN - a[i]])++ans;// 为了避免负数下标met[a[i] + MAXN] = 1;
}

复杂度分析

时间复杂度分析:对 a 数组遍历了一遍就能完成题目要求,当 n 足够大的时候时间复杂度为\Theta(n)

空间复杂度分析:\Theta( n + max { |x| :x \in a } )

OI Wiki 原文:枚举 - OI Wiki

~~~//仅当笔者个人备忘录使用。


http://www.ppmy.cn/ops/25809.html

相关文章

mysql UNION 联合查询

mysql UNION 联合查询 业务需要拉数据&#xff0c;这里需要对查询不同格式的数据进行组装&#xff0c;此处采用联合查询 注意1&#xff1a;null as 设备关爱 &#xff0c;结果为null&#xff0c;表头为设备关爱 注意2&#xff1a; UNION 或者 UNION ALL 联合查询自行选用 注意3…

NET Vastbase .NET 中操作和使用 Vastbase 海量数据库

功能成熟 需要升级到&#xff1a;5.1.4.111-preview06 及以上 已经有大量用户成功完成了项目&#xff0c;sqlsugar针对Vastbase 做了多处理&#xff0c;并且和Vastbase 处于合作关系 。有BUG可以及时找到官方 连接字符串 用法和PGSQL一样 &#xff0c;唯一区别 在连接字符串…

Linux的学习之路:22、线程(2)

摘要 本章继续讲一下线程的东西 目录 摘要 一、抢票 二、加锁保护 三、死锁 1、死锁四个必要条件 2、避免死锁 四、同步 1、常见的线程安全的情况 2、常见不可重入的情况 3、常见可重入的情况 4、可重入与线程安全联系 5、可重入与线程安全区别 一、抢票 这里回…

如何进行面向对象分析、面向对象设计和面向对象编程

目录 1.引言 2.案例介绍和难点剖析 3.如何进行面向对象分析 4.如何进行面向对象设计 5.如何进行面向对象编程 6.总结 1.引言 面向对象分析(OOA)、面向对象设计(00D)和面向对象编程(OOP)是面向对象开发的3个主要环节。 在以往的工作中&#xff0c;作者发现&#xff0c;很多…

使用Redis实现游戏排行榜

排行榜在当今应用中扮演着至关重要的角色。无论是游戏中的玩家排名、社交平台的用户活跃度榜单&#xff0c;还是其他领域的各种榜单&#xff0c;排行榜都是用户参与性和互动性的关键。在实现排行榜功能时&#xff0c;选择合适的数据库和数据结构至关重要。Redis&#xff0c;作为…

指纹浏览器:网络安全与隐私的新工具

在互联网时代&#xff0c;隐私和网络安全成为人们越来越关注的话题。随着数字化的发展&#xff0c;个人信息的泄露和在线追踪的问题愈发严峻。在这个背景下&#xff0c;"指纹浏览器"作为一种新型工具&#xff0c;开始受到关注。撸空投需要了解指纹浏览器。本文将深入…

以太网交换机自学习与转发帧

自学习算法:每次转发帧前先将当前MAC地址以及对应的接口好存入到帧交换表中

2024年3月电子学会Python等级考试试卷(二级)真题,包含答案

目录 真题pdf文件下载: 202403Python 二级真题 1、期末考试结束了,全班的语文成绩都储存在列表score 中,班主任老师请小明找到全班最高分,小明准备用Python 来完成,以下哪个选项,可以获取最高分呢?() A.min(score) B.max(score) Cscoremax() D.score.min() 正确答案:B…