搜索
首页后端开发C++通过生成二进制字符串的所有排列获得的不同数字

通过生成二进制字符串的所有排列获得的不同数字

Sep 04, 2023 pm 09:33 PM
字符串编程二进制排列数字生成

通过生成二进制字符串的所有排列获得的不同数字

问题陈述

我们给定了长度为 N 的二进制字符串 str。我们需要找到该字符串的所有排列,将它们转换为十进制值,并返回所有唯一的十进制值。

示例

输入

str = ‘1’

输出

[1]

说明

“1”的所有排列都只是“1”。因此,与“1”相关的十进制值等于 1。

输入

str = ‘10’

输出

[1, 2]

说明

‘10’的排列只有‘01’和‘10’,分别相当于1和2。

输入

‘101’

输出

[3, 5, 6]

说明

“101”的所有可能排列是“110”、“101”、“110”、“011”、“101”和“011”,如果我们将它们转换为十进制数字,我们会得到 3、5 ,以及 6 个唯一的十进制数。

方法 1

在第一种方法中,我们将使用回溯来获取二进制字符串的所有排列。之后,我们将二进制排列转换为十进制值,并使用该集合选择唯一的十进制值。我们将使用 pow() 方法和 for 循环将十进制转换为二进制。

算法

  • 第 1 步 - 定义“getDecimalPermutations()”函数以获取结果十进制值。

  • 第 2 步 - 执行“getBinaryPermutations()”函数以获取字符串的所有二进制排列。另外,还传递字符串、左右索引和排列向量作为参数。

  • 步骤 2.1 - 在“getBinaryPermutations()”函数中,如果左右索引相等,则将结果字符串推送到排列列表中。

  • 步骤 2.2 - 如果左右索引不相等,则使用 for 循环从左索引到右索引迭代字符串。

  • 步骤 2.3 - 在 for 循环中交换第 i 个索引和左侧索引处的字符。

  • 步骤 2.4 - 再次使用与参数相同的参数和“left + 1”索引调用“getBinaryPermutations”函数。

  • 步骤 2.5 - 交换第 i 个索引和左侧索引处的字符以实现回溯目的。

  • 第 3 步 - 创建一个名为“allDecimals”的集合。之后,迭代二进制字符串的所有排列。

  • 第 4 步 - 调用 bToD() 函数将二进制转换为十进制。

  • 步骤 4.1 - 在 bToD() 函数中,用 0 值初始化十进制变量。

  • 步骤 4.2 - 使用 for 循环从末尾开始迭代二进制字符串,并添加 '(num[i] - '0') * pow(2, j )' 转换为十进制值。

  • 步骤 4.3 - 返回十进制值。

  • 第 5 步 - 在“getDecimalPermutations”函数中,插入从 bToD() 函数返回的十进制值。

  • 第 6 步 - 打印该集合的所有值,其中将包含唯一的十进制值。

示例

#include <iostream>
#include <bits/stdc++.h>
using namespace std;
// Function to convert binary to decimal
int bToD(string num){
   int decimal = 0;
   for (int i = num.size() - 1, j = 0; i >= 0; i--, j++){
      decimal += (num[i] - '0') * pow(2, j);
   }
   return decimal;
}
// Function to get all permutations of a binary string
void getBinaryPermutations(string str, int left, int right, vector<string> &permutations){
   // Base case
   if (left == right){
      // push_back() function is used to push elements into a vector from the back
      permutations.push_back(str);
   } else {
      // Permutations made
      for (int i = left; i <= right; i++){
         // Swapping done
         swap(str[left], str[i]);
         // Recursion called for next index (left + 1)
         getBinaryPermutations(str, left + 1, right, permutations);
         // Backtrack
         swap(str[left], str[i]);
      }
   }
}
void getDecimalPermutations(string str){
   vector<string> permutations;
   getBinaryPermutations(str, 0, str.length() - 1, permutations);
   set<int> allDecimals;
   for (const auto &p : permutations){
      allDecimals.insert(bToD(p));
   }
   cout << "All decimal numbers which we can achieve using permutations are " << endl;
   for (const auto &d : allDecimals){
      cout << d << " ";
   }
}
int main(){
   string bString = "101";
   getDecimalPermutations(bString);
   return 0;
}

输出

All decimal numbers which we can achieve using permutations are 
3 5 6
  • 时间复杂度 - O(n!)。 “getBinaryPermutations()”函数的时间复杂度是“n!”,因为我们使用回溯来查找所有排列。 bToD() 函数的时间复杂度为 O(n)。

  • 空间复杂度 - O(n!)。每个字符串都有 n!我们存储在列表中的排列。

方法2

在这种方法中,我们将使用 C++ 的 next_permutation() 函数来生成二进制字符串排列,而不是回溯方法。此外,我们还更改了将二进制转换为十进制的方法。

算法

  • 第 1 步 - 定义“allNumbers”集。

  • 步骤 2 - sort() 方法用于对二进制字符串进行排序。

  • 第 3 步 - 使用 do-while 循环迭代字符串的每个排列。

  • 步骤 4 - 在 do-while 循环中,通过传递字符串作为参数来调用 bToD() 函数,以将二进制转换为十进制数字。

  • 步骤 4.1 - 在 bToD() 函数中,定义“currentBase”变量并将其初始化为 1。

  • 步骤 4.2 - 使用 for 循环,并从最后一个索引开始迭代字符串。

  • 步骤4.3 - 在for循环中,如果当前字符等于'1',我们需要将currentBase值添加到'decimal_number'。

  • 步骤 4.4 - 将 currentBase 乘以 2。

  • 第 5 步 - 将十进制数插入“allNumber”集中。

  • 第 6 步 - 在 do-while 循环的条件下使用 next_permutation() 方法,因为如果字符串的下一个排列存在,它将返回 true。

  • 第 7 步 - 打印“allNumbers”中添加的所有数字,以获得与给定二进制字符串的所有排列相关的唯一十进制数。

示例

#include <iostream>
#include <algorithm>
#include <set>

using namespace std;
int bToD(string num){
   int decimal_number = 0;
   // Initializing base value to 1, and it increases by power of 2 in each iteration
   int currentBase = 1;
   for (int i = num.length() - 1; i >= 0; i--){
      if (num[i] == '1'){
         decimal_number += currentBase;
      }
      currentBase = currentBase * 2;
   }
   return decimal_number;
}
void getDecimalPermutations(string str){
   // create set
   set<int> allNumbers;
   // sort the string
   sort(str.begin(), str.end());
   do {
      // convert binary string to decimal
      int result = bToD(str);
      // insert the decimal number to set
      allNumbers.insert(result);
      // get the next permutation
   } while (next_permutation(str.begin(), str.end()));
   //Print all distinct decimal numbers
   cout << "All decimal numbers which we can achieve using permutations are " << endl;
   for (auto num : allNumbers)
      cout << num << " ";
      cout << endl;
}
int main(){
   string bString = "101";
   getDecimalPermutations(bString);
   return 0;
}

输出

All decimal numbers which we can achieve using permutations are 
3 5 6
  • 时间复杂度 - O(n*n!)。这里,next_permutations() 需要 O(n) 时间来找到一个排列,并且我们正在找到总共 n!排列。

  • 空间复杂度 - O(n!),因为我们将所有排列存储在列表中。

结论

我们学习了不同的方法来获取通过给定二进制字符串的所有排列获得的唯一十进制值。在第一种方法中,我们使用了回溯;在第二种方法中,我们使用了 next_permutation() 方法。

第二种方法的代码更清晰,但需要更多的时间和复杂性。

以上是通过生成二进制字符串的所有排列获得的不同数字的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:tutorialspoint。如有侵权,请联系admin@php.cn删除
C面试问题和答案:ACE您的下一次技术评估C面试问题和答案:ACE您的下一次技术评估Apr 28, 2025 am 12:10 AM

C 面试中,智能指针是关键工具,帮助管理内存并减少内存泄漏。1)std::unique_ptr提供独占所有权,确保资源自动释放。2)std::shared_ptr用于共享所有权,适用于多引用场景。3)std::weak_ptr可避免循环引用,确保安全资源管理。

C的未来:改编和创新C的未来:改编和创新Apr 27, 2025 am 12:25 AM

C 的未来将专注于并行计算、安全性、模块化和AI/机器学习领域:1)并行计算将通过协程等特性得到增强;2)安全性将通过更严格的类型检查和内存管理机制提升;3)模块化将简化代码组织和编译;4)AI和机器学习将促使C 适应新需求,如数值计算和GPU编程支持。

C的寿命:检查其当前状态C的寿命:检查其当前状态Apr 26, 2025 am 12:02 AM

C 在现代编程中依然重要,因其高效、灵活和强大的特性。1)C 支持面向对象编程,适用于系统编程、游戏开发和嵌入式系统。2)多态性是C 的亮点,允许通过基类指针或引用调用派生类方法,增强代码的灵活性和可扩展性。

C#vs. C性能:基准测试和注意事项C#vs. C性能:基准测试和注意事项Apr 25, 2025 am 12:25 AM

C#和C 在性能上的差异主要体现在执行速度和资源管理上:1)C 在数值计算和字符串操作上通常表现更好,因为它更接近硬件,没有垃圾回收等额外开销;2)C#在多线程编程上更为简洁,但性能略逊于C ;3)选择哪种语言应根据项目需求和团队技术栈决定。

C:死亡还是简单地发展?C:死亡还是简单地发展?Apr 24, 2025 am 12:13 AM

1)c relevantduetoItsAverity and效率和效果临界。2)theLanguageIsconTinuellyUped,withc 20introducingFeaturesFeaturesLikeTuresLikeSlikeModeLeslikeMeSandIntIneStoImproutiMimproutimprouteverusabilityandperformance.3)

C在现代世界中:应用和行业C在现代世界中:应用和行业Apr 23, 2025 am 12:10 AM

C 在现代世界中的应用广泛且重要。1)在游戏开发中,C 因其高性能和多态性被广泛使用,如UnrealEngine和Unity。2)在金融交易系统中,C 的低延迟和高吞吐量使其成为首选,适用于高频交易和实时数据分析。

C XML库:比较和对比选项C XML库:比较和对比选项Apr 22, 2025 am 12:05 AM

C 中有四种常用的XML库:TinyXML-2、PugiXML、Xerces-C 和RapidXML。1.TinyXML-2适合资源有限的环境,轻量但功能有限。2.PugiXML快速且支持XPath查询,适用于复杂XML结构。3.Xerces-C 功能强大,支持DOM和SAX解析,适用于复杂处理。4.RapidXML专注于性能,解析速度极快,但不支持XPath查询。

C和XML:探索关系和支持C和XML:探索关系和支持Apr 21, 2025 am 12:02 AM

C 通过第三方库(如TinyXML、Pugixml、Xerces-C )与XML交互。1)使用库解析XML文件,将其转换为C 可处理的数据结构。2)生成XML时,将C 数据结构转换为XML格式。3)在实际应用中,XML常用于配置文件和数据交换,提升开发效率。

See all articles

热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

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

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。