目录
语法
算法
方法
方法 1:基于集合的方法
示例
输出
说明
方法2:排序方法
结论
首页 后端开发 C++ 检查给定的数组是否可以通过将元素减半来构成1到N的排列

检查给定的数组是否可以通过将元素减半来构成1到N的排列

Sep 10, 2023 pm 12:05 PM
数组检查 排列分割 减半

检查给定的数组是否可以通过将元素减半来构成1到N的排列

我们的目的是确定对数组中包含的每个项目执行多次除法是否会创建一个从 1 到 N 的没有任何重复项的整数列表。这项努力的成功将意味着我们的调查目标圆满实现。本质上,确定将给定数组中提供的所有元素切割两个是否会产生完全由 1 到 N 之间的非重复值组成的排列,这是我们工作的主要焦点。确认后,评估我们的论文将成为下一个合乎逻辑的步骤。

语法

在深入研究我们提出的解决方案之前,粗略地了解即将实现的方法的语法非常重要。

bool canBePermutation(vector<int>& arr)
{
   // Implementation goes here
}
</int>
登录后复制

算法

为了解决这个问题,让我们继续使用下面概述的算法来逐步进行 -

  • 要密切关注数组中观察到的组件,请从启动集合或哈希集开始。然后,迭代该数组中存在的每个元素。

  • 为了获得 1 到 N 之间的整数,需要将每个元素除以 2 多次。

  • 检查结果值是否已存在于集合中。如果是,则返回 false,因为排列中不能有重复项。

  • 为了使数组成为有效排列,每个元素都必须满足上述条件。假设完全满足此标准,通过提供 true 返回值来确认其资格可以被视为适当的行动方案。

方法

为了有效解决这个问题。探索不同的策略可能会有所帮助。我将提出两种可能的方法 -

方法 1:基于集合的方法

创建高效的方法需要使用细致的技术,例如使用创建的集合实施跟踪系统,以记录整个过程中遇到的组件。它涉及通过除法过程迭代评估每个组件,确保其结果值落在 1 到 N 个范围值之间,然后在附加新观察到的项目之前检查我们的跟踪集进行验证,然后如果有任何异常则返回 false,否则一旦所有值都返回 true通过星座要求的评估检查。

示例

#include <iostream>
#include <vector>
#include <unordered_set>

bool canBePermutation(std::vector<int>& arr) {
   std::unordered_set<int> seen;
   
   for (int num : arr) {
      while (num > 0 && num != 1) {
         if (seen.find(num) != seen.end())
            return false;
         
         seen.insert(num);
         num /= 2;
      }
      
      if (num == 0)
         return false;
   }
   
   return true;
}

int main() {
   std::vector<int> arr = {4, 2, 1, 3};
   
   if (canBePermutation(arr)) {
      std::cout << "The given array can be transformed into a permutation.";
   } else {
      std::cout << "The given array cannot be transformed into a permutation.";
   }
   
   return 0;
}
登录后复制

输出

The given array cannot be transformed into a permutation.
登录后复制

说明

方法 1 的初始步骤涉及设置一个无序集来跟踪数组中存在的元素。然后,这种编码方法会继续迭代同一数组中的每个元素,每次除以 2,将它们重复减少为 1 到 N 之间的整数。在这些迭代过程中,会检查同一集合中是否已经创建了看似已创建的项目;从而试图避免仅仅由于重复而导致的重复排列。在检测到这些重复排列产生的重复项时,将返回 false,就像在没有重复完成的情况下检查所有内容时一样 - 传递为 true - 有效地指示给定集合是否可以移动到其各自的排列中,同时最小化其组件通过减半。

方法2:排序方法

升序排序有助于检测每个数组项是否可以将其自身呈现为排序列表中的匹配值。如果这些项目都不满足这个标准,我们的输出将产生 false;但是,如果所有项目都通过此测试,它将返回 true。

示例

#include <iostream>
#include <vector>
#include <algorithm>

bool canBePermutation(std::vector<int>& arr) {
   std::sort(arr.begin(), arr.end());

   for (int i = 0; i < arr.size(); i++) {
      int expected = i + 1;
      while (arr[i] > 0 && arr[i] != expected)
         arr[i] /= 2;

      if (arr[i] != expected)
         return false;
   }
   
   return true;
}

int main() {
   std::vector<int> arr = {4, 2, 1, 3};
   
   if (canBePermutation(arr)) {
      std::cout << "The given array can be transformed into a permutation.";
   } else {
      std::cout << "The given array cannot be transformed into a permutation.";
   }
   
   return 0;
}
登录后复制

输出

The given array can be transformed into a permutation.
登录后复制

说明

根据方法 2(排序方法),我们首先按升序排列原始输入数组,然后再进一步进行代码例程检查。该代码随后对上述数组的每个单独元素运行各种迭代,同时检查它们是否可被二整除,直到它们达到根据其在新排序的索引值位置范围内的位置建立的指定和假定值。如果在这样的一轮迭代中存在任何不符合这些预定义关键条件的情况,那么我们的代码将结果描述为“假”,这表示无法实现将此数组转换为相应的顺序排列。与此同时,相反,每个合规元素都会产生“true”结果,从而为我们的数组重组目标提供可行的积极方向。

结论

在这篇文章中,我们深入研究了验证给定数组是否可以通过将其元素减半来转换为包含 1 到 N 范围内的数字的排列的挑战。我们为读者提供了有效解决这个问题的大纲、语法和算法过程。此外,我们还提供了两种可行的方法以及完整的 C++ 可执行代码示例。通过应用本文中强调的基于集合的技术或排序策略,读者可以满意地确定任何给定的数组是否符合合法排列的所有必要条件。

以上是检查给定的数组是否可以通过将元素减半来构成1到N的排列的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

C语言数据结构:树和图的数据表示与操作 C语言数据结构:树和图的数据表示与操作 Apr 04, 2025 am 11:18 AM

C语言数据结构:树和图的数据表示与操作树是一个层次结构的数据结构由节点组成,每个节点包含一个数据元素和指向其子节点的指针二叉树是一种特殊类型的树,其中每个节点最多有两个子节点数据表示structTreeNode{intdata;structTreeNode*left;structTreeNode*right;};操作创建树遍历树(先序、中序、后序)搜索树插入节点删除节点图是一个集合的数据结构,其中的元素是顶点,它们通过边连接在一起边可以是带权或无权的数据表示邻

C语言文件操作难题的幕后真相 C语言文件操作难题的幕后真相 Apr 04, 2025 am 11:24 AM

文件操作难题的真相:文件打开失败:权限不足、路径错误、文件被占用。数据写入失败:缓冲区已满、文件不可写、磁盘空间不足。其他常见问题:文件遍历缓慢、文本文件编码不正确、二进制文件读取错误。

c语言函数的基本要求有哪些 c语言函数的基本要求有哪些 Apr 03, 2025 pm 10:06 PM

C语言函数是代码模块化和程序搭建的基础。它们由声明(函数头)和定义(函数体)组成。C语言默认使用值传递参数,但也可使用地址传递修改外部变量。函数可以有返回值或无返回值,返回值类型必须与声明一致。函数命名应清晰易懂,使用驼峰或下划线命名法。遵循单一职责原则,保持函数简洁性,以提高可维护性和可读性。

c上标3下标5怎么算 c上标3下标5算法教程 c上标3下标5怎么算 c上标3下标5算法教程 Apr 03, 2025 pm 10:33 PM

C35 的计算本质上是组合数学,代表从 5 个元素中选择 3 个的组合数,其计算公式为 C53 = 5! / (3! * 2!),可通过循环避免直接计算阶乘以提高效率和避免溢出。另外,理解组合的本质和掌握高效的计算方法对于解决概率统计、密码学、算法设计等领域的许多问题至关重要。

c语言函数名定义 c语言函数名定义 Apr 03, 2025 pm 10:03 PM

C语言函数名定义包括:返回值类型、函数名、参数列表和函数体。函数名应清晰、简洁、统一风格,避免与关键字冲突。函数名具有作用域,可在声明后使用。函数指针允许将函数作为参数传递或赋值。常见错误包括命名冲突、参数类型不匹配和未声明的函数。性能优化重点在函数设计和实现上,而清晰、易读的代码至关重要。

C语言多线程编程:新手指南与疑难解答 C语言多线程编程:新手指南与疑难解答 Apr 04, 2025 am 10:15 AM

C语言多线程编程指南:创建线程:使用pthread_create()函数,指定线程ID、属性和线程函数。线程同步:通过互斥锁、信号量和条件变量防止数据竞争。实战案例:使用多线程计算斐波那契数,将任务分配给多个线程并同步结果。疑难解答:解决程序崩溃、线程停止响应和性能瓶颈等问题。

c语言函数的概念 c语言函数的概念 Apr 03, 2025 pm 10:09 PM

C语言函数是可重复利用的代码块,它接收输入,执行操作,返回结果,可将代码模块化提高可复用性,降低复杂度。函数内部机制包含参数传递、函数执行、返回值,整个过程涉及优化如函数内联。编写好的函数遵循单一职责原则、参数数量少、命名规范、错误处理。指针与函数结合能实现更强大的功能,如修改外部变量值。函数指针将函数作为参数传递或存储地址,用于实现动态调用函数。理解函数特性和技巧是编写高效、可维护、易理解的C语言程序的关键。

c语言如何输出倒数 c语言如何输出倒数 Apr 04, 2025 am 08:54 AM

如何在 C 语言中输出倒数?回答:使用循环语句。步骤:1. 定义变量 n 存储要输出的倒数数字;2. 使用 while 循环持续打印 n 直到 n 小于 1;3. 在循环体内,打印出 n 的值;4. 在循环末尾,将 n 减去 1 以输出下一个更小的倒数。

See all articles