目录
示例示例
说明
方法 1
算法
示例
输出
使用Bitset的方法
结论
首页 后端开发 C++ 根据给定条件,从数组中构建一个长度为K的二进制字符串

根据给定条件,从数组中构建一个长度为K的二进制字符串

Sep 09, 2023 pm 07:45 PM
二进制 数组 构建

根据给定条件,从数组中构建一个长度为K的二进制字符串

在本教程中,我们需要构造一个长度为 K 的二进制字符串,如果使用数组元素可以实现等于 I 的子集和,则它的第 i 个索引处应包含“1”。我们将学习两种解决问题的方法。在第一种方法中,我们将使用动态规划方法来检查子集和等于索引“I”是否可能。在第二种方法中,我们将使用位集通过数组元素查找所有可能的和。

问题陈述 - 我们给出了一个包含 N 个整数的数组。此外,我们还给出了表示二进制字符串长度的整数 M。我们需要创建一个长度为 M 的二进制字符串,使其遵循以下条件。

  • 如果我们能从数组中找到总和等于索引“I”的子集,则索引“I”处的字符为 1;否则为 0。

  • 我从1开始的索引。

示例示例

Input –  arr = [1, 2] M = 4
登录后复制
Output – 1110
登录后复制

说明

  • 总和等于 1 的子集是 {1}。

  • 总和等于 2 的子集是 {2}。

  • 总和等于 3 的子集是 {1, 2}。

  • 我们找不到总和等于 4 的子集,因此我们将 0 放在第 4 个索引处。

Input –  arr = [1, 3, 1] M = 9
登录后复制
Output – 111110000
登录后复制

说明

我们可以创建所有可能的组合,以使总和在1到5之间。所以,前5个字符是1,最后4个字符是0。

Input –  arr = [2, 6, 3] M = 6
登录后复制
Output – 011011
登录后复制

说明

使用数组元素无法得到等于1和4的和,因此我们将0放置在第一个和第四个索引位置。

方法 1

在这种方法中,我们将使用动态规划来检查是否可以使用数组元素构造等于索引'I'的总和。我们将为每个索引检查它,并将1或0附加到一个二进制字符串中。

算法

  • 步骤 1 - 创建大小为 N 的向量并使用整数值对其进行初始化。另外,定义字符串类型的“bin”变量并使用空字符串对其进行初始化。

  • 第二步 - 使用for循环使总迭代次数等于字符串长度。

  • 第三步 - 在for循环中,通过将数组N和索引值作为参数调用isSubsetSum()函数。

  • 步骤 4 - 如果 isSubsetSum() 函数返回 true,则将“1”附加到“bin”。否则,将“0”附加到“bin”。

  • 第 5 步 - 定义 isSubsetSum() 函数以检查是否可以使用数组元素求和。

  • 步骤 5.1 - 定义一个名为 dpTable 的二维向量。

  • 步骤 5.2 - 将 'dpTable[i][0]' 初始化为 true,因为总和为零总是可能的。这里,'I' 是索引值。

  • 步骤 5.3 - 将 'dpTable [0] [j]' 初始化为 false,因为空数组的和是不可能的。

  • 步骤 5.4 - 现在,使用两个嵌套循环。第一个循环从1到N进行迭代,另一个循环从1到sum进行迭代。

  • 步骤 5.5 - 在 for 循环中,如果当前元素的值大于总和,则忽略它。

  • 步骤 5.6 − 否则,包括或排除元素以获得总和。

  • 步骤 5.7 − 返回包含结果的 ‘dpTable[N][sum]’。

示例

#include <iostream>
#include <vector>
using namespace std;
// Function to check if subset-sum is possible
bool isSubsetSum(vector<int> &arr, int N, int sum){
   vector<vector<bool>> dpTable(N + 1, vector<bool>(sum + 1, false));
   
   // Base cases
   for (int i = 0; i <= N; i++)
   
      // If the sum is zero, then the answer is true
      dpTable[i][0] = true;
      
   // for an empty array, the sum is not possible
   for (int j = 1; j <= sum; j++)
      dpTable[0][j] = false;
      
   // Fill the dp table
   for (int i = 1; i <= N; i++){
      for (int j = 1; j <= sum; j++){
      
         // if the current element is greater than the sum, then we can't include it
         if (arr[i - 1] > j)
            dpTable[i][j] = dpTable[i - 1][j];
            
         // else we can either include it or exclude it to get the sum
         else
            dpTable[i][j] = dpTable[i - 1][j] || dpTable[i - 1][j - arr[i - 1]];
      }
   }
   
   // The last cell of the dp table contains the result
   return dpTable[N][sum];
}
int main(){

   // Given M
   int M = 9;
   
   // Creating the vector
   vector<int> arr = {1, 3, 1};
   
   // getting the size of the vector
   int N = arr.size();
   
   // Initializing the string
   string bin = "";
   
   // Making k iteration to construct the string of length k
   for (int i = 1; i <= M; i++){
   
      // if the subset sum is possible, then add 1 to the string, else add 0
      if (isSubsetSum(arr, N, i)){
         bin += "1";
      }
      else{
         bin += "0";
      }
   }
   
   // print the result.
   cout << "The constructed binary string of length " << M << " according to the given conditions is ";
   cout << bin;
   return 0;
}
登录后复制

输出

The constructed binary string of length 9 according to the given conditions is 111110000
登录后复制

时间复杂度 - O(N^3),因为 isSubsetSum() 的时间复杂度为 O(N^2),我们在驱动程序代码中调用它 N 次。

空间复杂度 - O(N^2),因为我们在isSubsetSum()函数中使用了一个二维向量。

使用Bitset的方法

在这种方法中,我们将使用位集通过组合数组的不同元素来查找所有可能的总和值。这里,bitset 意味着它创建一个二进制字符串。在结果位集中,它的每一位都代表总和是否可能等于特定索引,我们需要在这里找到它。

算法

  • 第 1 步 - 定义数组和 M。此外,定义 createBinaryString() 函数。

  • 第 2 步 - 接下来,定义所需长度的位集,这将创建一个二进制字符串。

  • 第三步 - 将bit[0]初始化为1,因为总和为0总是可能的。

  • 第 4 步 - 使用 for 循环迭代数组元素

  • 步骤 5 - 首先,对数组元素执行“bit”左移操作。然后将结果值与位值进行或运算。

  • 步骤 6 − 从索引 1 到 M 打印位集的值。

示例

#include <bits/stdc++.h>
using namespace std;
// function to construct the binary string
void createBinaryString(int array[], int N, int M){
   bitset<100003> bit;
   
   // Initialize with 1
   bit[0] = 1;
   
   // iterate over all the integers
   for (int i = 0; i < N; i++){
      // perform left shift by array[i], and OR with the previous value.
      bit = bit | bit << array[i];
   }
   
   // Print the binary string
   cout << "The constructed binary string of length " << M << " according to the given conditions is ";
   for (int i = 1; i <= M; i++){
      cout << bit[i];
   }
}
int main(){

   // array of integers
   int array[] = {1, 4, 2};
   int N = sizeof(array) / sizeof(array[0]);
   
   // value of M, size of the string
   int M = 8;
   createBinaryString(array, N, M);
}
登录后复制

输出

The constructed binary string of length 8 according to the given conditions is 11111110
登录后复制

时间复杂度 - O(N),因为我们使用单个 for 循环。

空间复杂度 - O(N),因为我们存储了位集的值。

结论

在这里,我们优化了第二种方法,从空间和时间复杂度来看,它比第一种方法更好。然而,如果你没有对位集的了解,第二种方法可能对初学者来说很难理解。

以上是根据给定条件,从数组中构建一个长度为K的二进制字符串的详细内容。更多信息请关注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)

如何使用 foreach 循环去除 PHP 数组中的重复元素? 如何使用 foreach 循环去除 PHP 数组中的重复元素? Apr 27, 2024 am 11:33 AM

使用foreach循环去除PHP数组中重复元素的方法如下:遍历数组,若元素已存在且当前位置不是第一个出现的位置,则删除它。举例而言,若数据库查询结果存在重复记录,可使用此方法去除,得到不含重复记录的结果。

PHP数组深度复制的艺术:使用不同方法实现完美复制 PHP数组深度复制的艺术:使用不同方法实现完美复制 May 01, 2024 pm 12:30 PM

PHP中深度复制数组的方法包括:使用json_decode和json_encode进行JSON编码和解码。使用array_map和clone进行深度复制键和值的副本。使用serialize和unserialize进行序列化和反序列化。

PHP 数组键值翻转:不同方法的性能对比分析 PHP 数组键值翻转:不同方法的性能对比分析 May 03, 2024 pm 09:03 PM

PHP数组键值翻转方法性能对比表明:array_flip()函数在大型数组(超过100万个元素)下比for循环性能更优,耗时更短。手动翻转键值的for循环方法耗时相对较长。

PHP数组多维排序实战:从简单到复杂场景 PHP数组多维排序实战:从简单到复杂场景 Apr 29, 2024 pm 09:12 PM

多维数组排序可分为单列排序和嵌套排序。单列排序可使用array_multisort()函数按列排序;嵌套排序需要递归函数遍历数组并排序。实战案例包括按产品名称排序和按销售量和价格复合排序。

深度复制PHP数组的最佳实践:探索高效的方法 深度复制PHP数组的最佳实践:探索高效的方法 Apr 30, 2024 pm 03:42 PM

在PHP中执行数组深度复制的最佳实践是:使用json_decode(json_encode($arr))将数组转换为JSON字符串,然后再将其转换回数组。使用unserialize(serialize($arr))将数组序列化为字符串,然后将其反序列化为新数组。使用RecursiveIteratorIterator迭代器对多维数组进行递归遍历。

PHP 数组分组函数在数据整理中的应用 PHP 数组分组函数在数据整理中的应用 May 04, 2024 pm 01:03 PM

PHP的array_group_by函数可根据键或闭包函数对数组中的元素分组,返回一个关联数组,其中键是组名,值是属于该组的元素数组。

PHP如何对数组中的值进行大小排序 PHP如何对数组中的值进行大小排序 Mar 22, 2024 pm 05:24 PM

PHP是一种常用的服务器端脚本语言,广泛应用于网站开发和数据处理领域。在PHP中,对数组中的值进行大小排序是很常见的需求。通过使用内置的排序函数,可以很方便地实现对数组的排序操作。下面将介绍如何使用PHP对数组中的值进行大小排序,并附上具体的代码示例:1.对数组中的值进行升序排序:

PHP 数组分组函数在查找重复元素中的作用 PHP 数组分组函数在查找重复元素中的作用 May 05, 2024 am 09:21 AM

PHP的array_group()函数可用于按指定键对数组进行分组,以查找重复元素。该函数通过以下步骤工作:使用key_callback指定分组键。可选地使用value_callback确定分组值。对分组元素进行计数并识别重复项。因此,array_group()函数对于查找和处理重复元素非常有用。

See all articles