2个回答
展开全部
关键是十六进制数转二进制数的算法。
十六进制数用数组装。 比如 abc,想变成二进制数,方法很多。
最简单的是定义,十六进制数和二进制数的兑换表,如a = 1010 b = 1011 c = 1100
然后直接代换,就ok了。这个对于大批量数据的转换,速度是相当快的。如果取巧,可以用什么乘除法,你可以去搜下。对后期学习有好处的。
十六进制数用数组装。 比如 abc,想变成二进制数,方法很多。
最简单的是定义,十六进制数和二进制数的兑换表,如a = 1010 b = 1011 c = 1100
然后直接代换,就ok了。这个对于大批量数据的转换,速度是相当快的。如果取巧,可以用什么乘除法,你可以去搜下。对后期学习有好处的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<iostream>
#include<string>
using namespace std;
int main()
{
string hexstr;
cin>>hexstr;
int len = hexstr.size();
int *p = new int[len*4];
int i;
for(i=0;i<len;i++)
{
switch(hexstr.at(i))
{
case '0':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case '1':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case '2':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case '3':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
case '4':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case '5':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case '6':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case '7':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
case '8':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case '9':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case 'A':
case 'a':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case 'b':
case 'B':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
case 'C':
case 'c':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case 'D':
case 'd':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case 'E':
case 'e':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case 'F':
case 'f':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
}
}
for(i=0;i<len*4;i++)
{
cout<<p[i];
}
delete []p;
return 0;
}
#include<string>
using namespace std;
int main()
{
string hexstr;
cin>>hexstr;
int len = hexstr.size();
int *p = new int[len*4];
int i;
for(i=0;i<len;i++)
{
switch(hexstr.at(i))
{
case '0':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case '1':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case '2':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case '3':
{
p[4*i+0]=0;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
case '4':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case '5':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case '6':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case '7':
{
p[4*i+0]=0;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
case '8':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case '9':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case 'A':
case 'a':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case 'b':
case 'B':
{
p[4*i+0]=1;
p[4*i+1]=0;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
case 'C':
case 'c':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=0;
break;
}
case 'D':
case 'd':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=0;
p[4*i+3]=1;
break;
}
case 'E':
case 'e':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=0;
break;
}
case 'F':
case 'f':
{
p[4*i+0]=1;
p[4*i+1]=1;
p[4*i+2]=1;
p[4*i+3]=1;
break;
}
}
}
for(i=0;i<len*4;i++)
{
cout<<p[i];
}
delete []p;
return 0;
}
追问
怎么用移位(左移、右移)的方式实现?????
追答
不会。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询