首页 > 后端开发 > C++ > 长度为n的所有可能的二进制数,两半部分的和相等?

长度为n的所有可能的二进制数,两半部分的和相等?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2023-09-03 13:21:11
转载
1173 人浏览过

长度为n的所有可能的二进制数,两半部分的和相等?

这里我们将看到所有可能的n位二进制数(n由用户给出),其中每一半的和相同。例如,如果数字是 10001,这里 10 和 01 是相同的,因为它们的总和相同,并且它们位于不同的一半。在这里,我们将生成该类型的所有数字。

算法

genAllBinEqualSumHalf(n, left, right, diff)

左和右最初为空,diff 保存左右之间的差异

Begin
   if n is 0, then
      if diff is 0, then
         print left + right
      end if
      return
   end if
   if n is 1, then
      if diff is 0, then
         print left + 0 + right
         print left + 1 + right
      end if
      return
   end if
   if 2* |diff| <= n, then
      if left is not blank, then
         genAllBinEqualSumHalf(n-2, left + 0, right + 0, diff)
         genAllBinEqualSumHalf(n-2, left + 0, right + 1, diff-1)
      end if
      genAllBinEqualSumHalf(n-2, left + 1, right + 0, diff + 1)
      genAllBinEqualSumHalf(n-2, left + 1, right + 1, diff)
   end if
End
登录后复制

示例

#include <bits/stdc++.h>
using namespace std;
//left and right strings will be filled up, di will hold the difference between left and right
void genAllBinEqualSumHalf(int n, string left="", string right="", int di=0) {
   if (n == 0) { //when the n is 0
      if (di == 0) //if diff is 0, then concatenate left and right
         cout << left + right << " ";
      return;
   }
   if (n == 1) {//if 1 bit number is their
      if (di == 0) { //when difference is 0, generate two numbers one with 0 after left, another with 1 after left, then add right
         cout << left + "0" + right << " ";
         cout << left + "1" + right << " ";
      }
      return;
   }
   if ((2 * abs(di) <= n)) {
      if (left != ""){ //numbers will not start with 0
         genAllBinEqualSumHalf(n-2, left+"0", right+"0", di);
         //add 0 after left and right
         genAllBinEqualSumHalf(n-2, left+"0", right+"1", di-1);
         //add 0 after left, and 1 after right, so difference is 1 less
      }
      genAllBinEqualSumHalf(n-2, left+"1", right+"0", di+1); //add 1 after left, and 0 after right, so difference is 1 greater
      genAllBinEqualSumHalf(n-2, left+"1", right+"1", di); //add 1 after left and right
   }
}
main() {
   int n = 5;
   genAllBinEqualSumHalf(n);
}
登录后复制

输出

rree

以上是长度为n的所有可能的二进制数,两半部分的和相等?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
page-header怎么控制长度?
来自于 1970-01-01 08:00:00
0
0
0
fread($fp, 1024);读取长度是指什么啊?
来自于 1970-01-01 08:00:00
0
0
0
自增长有长度限制么
来自于 1970-01-01 08:00:00
0
0
0
javascript - js设置数组的最大长度
来自于 1970-01-01 08:00:00
0
0
0
如何在Vue.js中获取数组的总长度
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板