赞
踩
输入八位二进制数据转成十进制
思想:逐位读入输入的八位二进制,判断该位是否为‘1’,若为1,则该位值为2的 i 次方(该位为第 i 位),每位对应值累加结果为所求十进制
输入11011010,读入第一个数据为1,第七位(从右往左,0到7),对应值为2的7次方即128
第二个数据为1,第六位,对应值为64......
代码:
#include "stdafx.h"
#include <iostream>
using namespace std;
double power (double x,int n);//声明函数原型
int _tmain(int argc, _TCHAR* argv[])
{
int value=0;
cout<<"please input an 8 bit binary number:";
for (int i=7;i>=0;i--)
{
char ch;
cin>>ch;
if(ch=='1')
{
value += static_cast<int>(power(2,i));//强制类型转换
}
}
cout<<"Decimal value is:"<<value<<endl;
system("pause");
return 0;
}
double power(double x,int n)
{
double val =1.0;
while(n--)//相当于while(n&&n=n-1)
//n是bool型变量时,就是代表n为true时运行循环,
//n是int型时,就是代表不为0时运行循环
//n为表达式,就代表表达式成立时运行循环
val*=x;
return val;
}
运行结果:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。