| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1372 人关注过本帖
标题:如何将文本中的16进制数据转换为2进制数组
只看楼主 加入收藏
Ocean218
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2011-5-12
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:8 
如何将文本中的16进制数据转换为2进制数组
如何将文本中的16进制数据转换为2进制数组
搜索更多相关主题的帖子: 如何 
2011-05-12 16:34
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:5 
实际上就是完成ASCII到integer的转换。有个atoi函数可以实现吧。

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-12 17:00
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
程序代码:
root@~ #cat stob.c
#include <stdio.h>
#include <string.h>

int main (void) {

        char str[10],*p=str;
        int a[32],i=0,j=1,k,sum=0,l=0,*s=a;

//input hex string
        printf("Enter a Hex-string:");
        gets(p);

//point to the right of character
        p=str+strlen(p)-1;

//From character to integer,Result in Sum.
        while(*p) {
                if(*p>='0'&&*p<='9') {
                        sum+=(*p-'0')*j;
                }
                else if(*p>='a'&&*p<='f') {
                        sum+=(*p-'a'+10)*j;
                }
                else {
                        printf("Input Error! Exit!\n");
                        return -1;
                }
                j*=16;
                p--;
        }

//Convert to binary array,Reslut in a[]
        do {
                a[i]=sum%2;
                sum/=2;
                i++;
        }while(sum!=0);

//Reverse array
        j=i-1;
        for(k=0;k<=j/2;k++,j--) {
                sum=a[k];
                a[k]=a[j];
                a[j]=sum;
        }

//Display binary array
        printf("%s's binary is : ",str);
        while(l<i) printf("%i",*(s+l++));
        printf("\n");

        return 0;

}
测试:
root@~ #./stob
Enter a Hex-string:f
f's binary is : 1111
root@~ #./stob
Enter a Hex-string:1234abcd
1234abcd's binary is : 10010001100101010011111001101
root@~ #./stob
Enter a Hex-string:sdf4
Input Error! Exit!
root@~ #./stob
Enter a Hex-string:ffff
ffff's binary is : 1111111111111111
root@~ #


[ 本帖最后由 ansic 于 2011-5-13 10:30 编辑 ]

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-13 10:29
Ocean218
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2011-5-12
收藏
得分:0 
1234abcd's binary is : 10010001100101010011111001101
1234输出的二进制怎么是错的?
2011-05-13 15:53
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
问题也许出在逆序存放的那段。

[ 本帖最后由 ansic 于 2011-5-13 16:19 编辑 ]

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-13 16:16
帅的让人抽
Rank: 4
来 自:安徽
等 级:业余侠客
帖 子:94
专家分:224
注 册:2010-9-30
收藏
得分:5 
很简单……

樱花下落的速度依然是秒速五厘米,即使发了一千次短信,
心与心之间也只能靠近一厘米……
2011-05-13 16:17
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
这样就可以了。
程序代码:

//Reverse array
        j=i-1;
        for(k=0;k<(i-1)/2;k++,j--) {
                sum=a[k];
                a[k]=a[j];
                a[j]=sum;
        }

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-13 16:27
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
以下是引用帅的让人抽在2011-5-13 16:17:04的发言:

很简单……

⊙﹏⊙b汗,高手觉得当然很简单啦~

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-13 16:28
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:5 
直接用楼上说的库函数就可以了

如果不用库函数用栈转化

                                         
===========深入<----------------->浅出============
2011-05-13 19:10
快速回复:如何将文本中的16进制数据转换为2进制数组
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.052208 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved