| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1292 人关注过本帖
标题:请高手帮我解决下面的试题,拜托,急!
只看楼主 加入收藏
csynyk
Rank: 1
等 级:新手上路
威 望:1
帖 子:114
专家分:0
注 册:2008-8-9
收藏
得分:0 
用另外一种思路给你写了段代码,这个效率应该比前面那个逐位判断的方法要快很多!

程序代码:
#include<stdio.h>

typedef  unsigned char BYTE;
typedef struct  //bit型位结构体       
{
    unsigned char bit0:1;
    unsigned char bit1:1;
    unsigned char bit2:1;
    unsigned char bit3:1;
    unsigned char bit4:1;
    unsigned char bit5:1;
    unsigned char bit6:1;
    unsigned char bit7:1;
}bit_array;    

/*............显示传入参数的二进制形式.........*/

void byte_change(BYTE* str, unsigned int len)   
{
    BYTE i=0;
    bit_array *temp=NULL;
    temp=(bit_array *)str;   //强制转换类型
    while(i<len)
    {
        printf("%d%d%d%d%d%d%d%d ", (temp+i)->bit7,  (temp+i)->bit6,
                        (temp+i)->bit5,  (temp+i)->bit4,
                        (temp+i)->bit3,  (temp+i)->bit2,
                        (temp+i)->bit1,  (temp+i)->bit0);
        i++;
    }
}
int main(void)
{
    BYTE array[]={8,7,6,5,4,3,2,1};    //代转换的数组
    byte_change(array,sizeof(array)/sizeof(array[0]));
    printf("\n");
    return 0;
}

http://blog./csynyk
2008-08-13 13:37
s_lujun
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2008-8-12
收藏
得分:0 
谢谢你的帮助!

[[it] 本帖最后由 s_lujun 于 2008-8-13 17:49 编辑 [/it]]
2008-08-13 17:48
iFreeBSD
Rank: 4
等 级:业余侠客
威 望:4
帖 子:474
专家分:236
注 册:2007-11-5
收藏
得分:0 
#include <stdio.h>
#include <limits.h>
#include <string.h>
#define MAX_SIZE  256
typedef char byte ;
void DisplayBin(byte  * ptr ) {
                unsigned int len = strlen(ptr) ;
                unsigned int  i = 0 ;
                unsigned short mask = 0x0 ;
                while(i<= len )
                      ptr[i] = ptr[i++] - '0' ;
                i = 0 ;
                while(i < len) {
                      mask = 0x1 << CHAR_BIT - 1 ;
                      while(mask){
                            putchar((mask & *ptr)?'1':'0') ;
                            mask >>= 0x1 ;

                      }
                      i++ ;
                      ptr++ ;
                      putchar(' ') ;
                }
                putchar('\n') ;
 return  ;
}

int main(void) {
         byte  arr[MAX_SIZE] ;
         scanf("%[0-9]s" ,arr) ;
         DisplayBin(arr) ;
 return 0 ;
 }

without further ado, let’s get started
2008-08-13 20:55
快速回复:请高手帮我解决下面的试题,拜托,急!
数据加载中...
 
   



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

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