0

0

在C++中,将一个数字表示为最小可能的伪二进制数之和

WBOY

WBOY

发布时间:2023-08-25 20:33:22

|

1335人浏览过

|

来源于tutorialspoint

转载

在c++中,将一个数字表示为最小可能的伪二进制数之和

本教程将讨论将一个数字表示为最小伪二进制数之和。伪二进制数是由二进制数字0和1组成的数字。伪二进制数的例子有00、11、10、100、111、1011等。

以下是一些以伪二进制数之和表示的数字的示例。

Input : 23
Output : 11 + 11 + 1
Explanation : 23 = 11 + 11 + 1, sum of pseudo-binary numbers(11, 11, 1) is 23.

Input : 50
Output : 10 + 10 + 10 + 10 + 10

寻找解决方案的方法

以下是寻找表示N的最小伪二进制数的最佳方法之一。

  • 取一个数字X,并根据数字N的各个位更新X的位数为1或0。

    立即学习C++免费学习笔记(深入)”;

  • 检查N的每个位数:

    • 如果为0,则将X的该位设为0。

    • 如果不为0,则将X的该位设为1。

    • 假设N = 32,则X将变为11。

      ClippingMagic
      ClippingMagic

      魔术般地去除图片背景

      下载
  • 然后X将成为一个伪二进制数。

  • 现在将N减去X,并重复步骤1,直到N变为零。

示例

上述方法的C++代码

#include
using namespace std;
int main(){
   int N = 51;
   // find a pseudo-binary number until N becomes 0.
   cout << "pseudo-binary representation of " << N << " is: ";
   while (N > 0){                
      // finding X which contains 0's and 1's according to N.
      int temp = N;
      int X = 0, bit = 1;
      // checking each place of N for zero or non-zero.
      while (temp!=0){
      int last_dig = temp % 10;
      temp = temp / 10;
      if (last_dig != 0)
         X += bit;
         bit *= 10;
      }
      // printing one pseudo-binary number.
      cout << X << " ";
      // Updating N by subtracting with X.
      N = N - X;
       
   }
   return 0;
}

输出

pseudo-binary representation of 51 is: 11 10 10 10 10

理解代码

  • 一个外部while循环用于获取N并在每个位置上选择数字以找到X。

  • 我们通过将N的值更新到temp变量中,并使用内部循环检查temp变量的每个位置并更新变量X的该位置。

  • 打印X的值,因为它是一个伪二进制数。

  • 我们通过将N减去X并再次进入外部循环,直到N变为0来更新N。

结论

在本教程中,我们讨论了如何将一个数表示为最小可能的伪二进制数之和。我们讨论了找到所有伪二进制数的方法。我们还讨论了相同的C++代码,我们可以用其他编程语言如C、Java、Python等编写。希望您会发现本教程有帮助。

相关专题

更多
c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

26

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

24

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

72

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

9

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

10

2026.01.09

俄罗斯手机浏览器地址汇总
俄罗斯手机浏览器地址汇总

汇总俄罗斯Yandex手机浏览器官方网址入口,涵盖国际版与俄语版,适配移动端访问,一键直达搜索、地图、新闻等核心服务。

52

2026.01.09

漫蛙稳定版地址大全
漫蛙稳定版地址大全

漫蛙稳定版地址大全汇总最新可用入口,包含漫蛙manwa漫画防走失官网链接,确保用户随时畅读海量正版漫画资源,建议收藏备用,避免因域名变动无法访问。

183

2026.01.09

php学习网站大全
php学习网站大全

精选多个优质PHP入门学习网站,涵盖教程、实战与文档,适合零基础到进阶开发者,助你高效掌握PHP编程。

12

2026.01.09

php网站搭建教程大全
php网站搭建教程大全

本合集专为零基础用户打造,涵盖PHP网站搭建全流程,从环境配置到实战开发,免费、易懂、系统化,助你快速入门建站!

8

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.4万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

【李炎恢】ThinkPHP8.x 后端框架课程
【李炎恢】ThinkPHP8.x 后端框架课程

共50课时 | 4.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号