将任一整数转换为二进制形式

2024-01-10 13:32

本文主要是介绍将任一整数转换为二进制形式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(1)方法1-----递归方法调用---通过进制转换规则进行

//将任一整数转换为n进制形式----进制转换法
//注意:对于要转换成16进制形式,必须考虑到10,11,12,13,14,15必须用英文字母A,B,C,D,E,F表示#include <iostream>
using namespace std;int main()
{void print10_2(int n,int d);  //函数声明int x,y;cout<<"输入你想转换的数"<<endl;cin>>x;cout<<"输入你想转换的进制"<<endl;cin>>y;cout<<x<<"的"<<y<<"进制数为:";print10_2(x,y);  //函数调用cout<<endl;return 0;
}void print10_2(int n,int d)  //递归函数求数n的d进制数
{ int m;if(n>=d)print10_2(n/d,d) ; //递归调用if(d==2||d==8)cout<<n%d; if(d==16){m=n%d;if(m<10)cout<<m;elseswitch(m){case 10:cout<<'A';break;case 11:cout<<'B';break;case 12:cout<<'C';break;case 13:cout<<'D';break;case 14:cout<<'E';break;case 15:cout<<'F';break;}  }
}


 


 

 

 

(2)方法2-----递归方法调用---通过移位方式进行

 

//将任一整数转换为二进制形式----方法2--移位法
/*问题分析与算法设计
将十进制整数转换为二进制的方法很多,这里介绍的实现方法利用了C++语言能够对位进行操作的特点。
对于C++语言来说,一个整数在计算机内就是以二进制的形式存储的,
所以没有必要再将一个整数经过一系列的运算转换为二进制形式,只要将整数在内存中的二进制表示输出即可。
*/
#include<iostream>
using namespace std;
void printb(int,int);
int main()
{int x;cout<<"Input number:";cin>>x;cout<<"number of decimal form:"<<x<<endl;cout<<" it's binary form:";printb(x,sizeof(int)*8);cout<<endl;;
}void printb(int x,int n)//递归函数
{if(n>0){putchar('0'+((unsigned)(x&(1<<(n-1)))>>(n-1)));printb(x,n-1);}
}



(3)利用数组实现

#include <iostream>
using namespace std;
int main()
{int n;cout<<"请输入待转换的十进制数:";cin>>n;int number[100];//进制转换int m,j,trans;for(int i=0;i<=2;i++) //i来控制外层循环次数,分别进行2进制、8进制、16进制转换{j=0;m=n;if(i==0) trans=2; //trans存储要进行转换的进制数if(i==1) trans=8;if(i==2) trans=16;while(m!=0)                  //辗转相除到商为0{number[j++]=m%trans;  m=m/trans;}cout<<"转换为"<<trans<<"进制,"<<n<<"是:";j--;while(j>=0)                    //余数倒序输出{char ch;if(number[j]>=0&&number[j]<=9)ch=number[j]+'0';else ch=number[j]-10+'A';     //处理十六进制的字符'A'--'Z'cout<<ch;j--;}cout<<endl;}
}


这篇关于将任一整数转换为二进制形式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/590984

相关文章

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Java将时间戳转换为Date对象的方法小结

《Java将时间戳转换为Date对象的方法小结》在Java编程中,处理日期和时间是一个常见需求,特别是在处理网络通信或者数据库操作时,本文主要为大家整理了Java中将时间戳转换为Date对象的方法... 目录1. 理解时间戳2. Date 类的构造函数3. 转换示例4. 处理可能的异常5. 考虑时区问题6.

基于C#实现将图片转换为PDF文档

《基于C#实现将图片转换为PDF文档》将图片(JPG、PNG)转换为PDF文件可以帮助我们更好地保存和分享图片,所以本文将介绍如何使用C#将JPG/PNG图片转换为PDF文档,需要的可以参考下... 目录介绍C# 将单张图片转换为PDF文档C# 将多张图片转换到一个PDF文档介绍将图片(JPG、PNG)转

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

通信工程学习:什么是2ASK/BASK二进制振幅键控

2ASK/BASK:二进制振幅键控         2ASK/BASK二进制振幅键控是一种数字调制技术,其全称是二进制振幅键控(Binary Amplitude Shift Keying)。该技术通过改变载波的振幅来传递二进制数字信息,而载波的频率和相位则保持不变。以下是关于2ASK/BASK二进制振幅键控的详细解释: 一、2ASK/BASK二进制振幅键控的基本原理 1、振幅键控: