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

根据给定条件,从数组中构建一个长度为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 #include using namespace std;// Function to check if subset-sum is possiblebool isSubsetSum(vector &arr, int N, int sum){   vector<vector> dpTable(N + 1, vector(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  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 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 using namespace std;// function to construct the binary stringvoid createBinaryString(int array[], int N, int M){   bitset 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的二进制字符串的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1444768.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 21:51:34
下一篇 2025年12月17日 21:51:53

相关推荐

  • 用numpy进行数组尺寸交换

    使用Numpy实现数组维度交换 Numpy是一个功能强大的Python库,用于进行科学计算和数据处理。它包含了丰富的函数和工具,可以方便地对数组进行各种操作,其中之一就是数组维度的交换。本文将介绍如何使用Numpy实现数组维度交换,并给出具体的代码示例。 首先,我们需要导入Numpy库: impor…

    2025年12月21日
    000
  • js中reduce在数组的使用

    reduce方法用于将数组归约为单一值,通过累加器函数遍历元素,可实现求和、扁平化、统计和分组;需注意初始值设置以避免空数组报错。 在 JavaScript 中,reduce 是数组的一个高阶方法,用于将数组“归约”为一个单一的值。它通过遍历数组每个元素,执行一个累加器函数,最终返回一个结果。这个方…

    2025年12月21日
    000
  • Node.js中如何操作数组?

    Node.js中操作数组与JavaScript一致,常用方法包括push、pop、slice、splice等,处理大型数组时需关注性能,建议使用流式处理或for循环提升效率;读取文件转数组可通过fs模块读取后用split分割,复杂CSV推荐csv-parse库;数据过滤转换可用filter、map、…

    2025年12月20日
    000
  • javascript如何实现数组响应式更新

    javascript实现数组响应式更新的核心是拦截数组的修改操作并在修改后通知依赖更新;2. 由于直接修改数组不会触发setter,因此需通过拦截数组方法或使用proxy实现;3. 拦截数组方法是通过重写push、pop、shift、unshift、splice、sort、reverse等方法,在调…

    2025年12月20日 好文分享
    000
  • javascript如何交换数组的前后部分

    交换数组前后部分的核心是使用slice和concat方法实现非破坏性操作,1. 通过math.max和math.min确保分割索引在有效范围内;2. 使用slice(0, splitindex)提取前部分;3. 使用slice(splitindex)提取后部分;4. 用concat将后部分与前部分连…

    2025年12月20日
    000
  • javascript如何求数组交集

    javascript求数组交集的常见方法包括:1. 循环嵌套,时间复杂度为o(nm),性能较差;2. filter结合includes,代码简洁但时间复杂度仍为o(nm);3. 使用set,将一个数组转为set后遍历另一数组查找,时间复杂度为o(n+m),性能更优;4. 排序后双指针法,适用于有序数…

    2025年12月20日 好文分享
    000
  • javascript数组如何移除第一个元素

    要移除 javascript 数组的第一个元素,最常用的方法是使用 shift() 方法,它会直接修改原数组并返回被移除的元素;1. 使用 shift() 是最直接的方式,如 let firstelement = myarray.shift(),执行后原数组变为 [2, 3, 4, 5],first…

    2025年12月20日 好文分享
    000
  • javascript怎么删除数组中的特定元素

    使用filter()方法可创建一个不包含特定元素的新数组,且不改变原数组,适用于需要保持原数组不变的场景;2. 使用splice()方法可直接在原数组上删除指定元素,需先通过indexof()或findindex()获取索引,适用于需原地修改数组的场景;3. 删除多个相同元素时,filter()更简…

    2025年12月20日 好文分享
    000
  • js如何实现数组映射

    在javascript中,实现数组映射的核心方式是使用内置的 map() 方法。1. map() 方法通过接受一个回调函数,为原数组的每个元素生成新值,最终返回一个新数组,不修改原始数组,体现了函数式编程的不变性原则;2. 相较于 foreach() 和 for 循环,map() 更适合“一对一”数…

    2025年12月20日
    000
  • javascript数组如何比较大小

    javascript数组不能直接用>或 JavaScript数组本身并没有一个像数字那样直接的“大于”或“小于”操作符来比较大小。当你尝试用 > 或 < 去比较两个数组时,JavaScript会尝试将它们转换为原始值(通常是字符串),然后进行比较,这往往得不到你想要的结果。所以,当…

    2025年12月20日 好文分享
    000
  • javascript如何检查变量是否为数组

    判断 javascript 变量是否为数组的核心方法是使用 array.isarray(),因为它能准确识别数组类型且不受跨 frame 环境影响;2. instanceof 操作符也可用于判断,但在跨 frame 场景下可能失效,因其依赖原型链检查;3. 对于老旧浏览器,可使用 polyfill …

    2025年12月20日 好文分享
    100
  • js 怎样比较两个数组是否相同

    在javascript中不能直接用==或===比较数组,因为它们比较的是引用地址而非内容,即使两个数组元素相同,只要不是同一对象实例,结果就为false;要准确判断数组内容是否一致,需进行逐元素比较,对于只含原始类型的数组可使用浅层比较函数如shallowarrayequal,通过检查长度和ever…

    2025年12月20日
    000
  • javascript怎么实现数组环形缓冲区

    javascript实现环形缓冲区的核心是使用固定大小数组和头尾指针配合模运算实现高效fifo操作。1. 其应用场景包括实时数据流处理(如webrtc音视频帧)、固定大小日志记录、撤销重做功能、固定缓存和游戏事件队列,均需满足固定容量、先进先出、自动淘汰旧数据的需求。2. 性能优化策略包括合理设定初…

    2025年12月20日 好文分享
    100
  • javascript怎么实现数组发布订阅

    首先,实现数组的发布订阅需创建事件中心并拦截数组操作;1. 设计高效模式时,使用哈希表存储事件与回调映射,支持事件命名空间与优先级;2. 避免内存泄漏需提供取消订阅机制,并可采用weakmap自动清理无效引用;3. 性能优化包括合并事件触发、异步执行耗时回调、应用节流防抖技术,以及选用高效数据结构提…

    2025年12月20日
    000
  • js如何实现数组填充

    填充javascript数组的常用方法有:1. 使用array.prototype.fill()可快速用单一值填充整个或部分数组,但需注意引用类型共享问题;2. 使用for或foreach循环可精确控制填充过程,适合复杂逻辑;3. array.from()结合映射函数能创建并动态填充新数组,尤其适合…

    2025年12月20日
    000
  • js如何将字符串转换为数组

    在javascript中,将字符串转换为数组的核心方法是使用split()。1. 使用split()可根据指定分隔符将字符串分割成数组,如str.split(“,”)可按逗号分割;2. 当存在连续分隔符时,split()会保留空字符串元素,可通过filter(boolean)…

    2025年12月20日 好文分享
    000
  • javascript怎么实现数组滑动窗口

    滑动窗口可通过双指针维护一个动态子数组来高效解决连续子序列问题,其核心是通过扩展和收缩窗口寻找满足条件的最短或最长子数组;具体步骤为:①初始化start和end指针为0;②扩展end指针并累加元素直至满足条件;③收缩start指针并更新结果,直到不再满足条件;④记录过程中最优解;例如求和为targe…

    2025年12月20日 好文分享
    000
  • js怎么合并两个数组不去重

    合并两个数组且不去除重复项最直接的方法是使用concat()或展开运算符。1. 使用array.prototype.concat()方法可创建新数组,不修改原数组,支持多个数组或值的合并。2. 使用展开运算符(…)语法更简洁,灵活性高,适合现代javascript开发,在可读性和代码简洁…

    2025年12月20日
    000
  • javascript怎么实现数组差集

    javascript实现数组差集的方法有多种,最直接的是使用循环遍历结合set提高查找效率;其次可用filter配合includes,代码简洁但性能较低;对于对象数组,需自定义比较函数,如通过differenceby结合some进行属性比对;还可利用哈希表优化性能,适用于基本类型元素的大数组;若数组…

    2025年12月20日 好文分享
    000
  • js 如何使用range生成指定范围的数组

    循环方式通过for循环逐个添加元素,代码直观但冗长;2. array.from结合长度和映射函数生成数组,现代且可读性强;3. 扩展运算符配合array.keys()利用索引映射生成数组,写法巧妙但性能略低;4. 递归方式不推荐,因效率低且有栈溢出风险;对于步长和倒序需求,可在array.from基…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信