| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 658 人关注过本帖
标题:学到了位运算...有点晕了...
只看楼主 加入收藏
Ryker
Rank: 6Rank: 6
等 级:侠之大者
威 望:1
帖 子:145
专家分:420
注 册:2013-2-19
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:8 
学到了位运算...有点晕了...
写了个把二进制字符串转换为十进制数的函数...

书上答案说是25...我怎么算也算不出来25啊.基本确定书上答案是错的了..

但还是不放心...求指点,我这么做对不对?

用位运算的话,这程序有没有更好的方法

程序代码:
#include <stdio.h>
#include <string.h>
#include <math.h>
int toint(char *);

int main(void)
{
    char pbin[] = "01001001";
    int sum = toint(pbin);
    printf("%d\n", sum);
    return 0;
}

int toint(char *bin)
{
    int sum = 0;
    int tmp;
    int len = strlen(bin) - 1;
    while(len >= 0)
    {
        tmp = *bin - '0';
        tmp <<= len--;
        sum += tmp;
        bin++;
        //sum += (*bin++ - '0') << len--;  这样写太不直观...我分开写了
    }
    return sum;
}


[ 本帖最后由 Ryker 于 2013-5-18 17:29 编辑 ]
搜索更多相关主题的帖子: 二进制 十进制 字符串 
2013-05-18 17:24
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:7 
很好了啊

就是 len有点多余  while ('\0' != *bin) 就行了


[fly]存在即是合理[/fly]
2013-05-19 01:14
Ryker
Rank: 6Rank: 6
等 级:侠之大者
威 望:1
帖 子:145
专家分:420
注 册:2013-2-19
收藏
得分:0 
以下是引用azzbcc在2013-5-19 01:14:47的发言:

很好了啊

就是 len有点多余  while ('\0' != *bin) 就行了


len可以不用吗?

我的思路是从高位开始,取数组一个字符,然后右移 len - 1位

累加

位操作实在是不太好理解... CPP这一章也不长,介绍的也不详细..
2013-05-19 08:42
YJ_Hao
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:1
帖 子:215
专家分:609
注 册:2013-3-22
收藏
得分:7 
因为用到并不多!
2013-05-19 08:51
Ryker
Rank: 6Rank: 6
等 级:侠之大者
威 望:1
帖 子:145
专家分:420
注 册:2013-2-19
收藏
得分:0 
我先跳过位操作这部分.
2013-05-19 09:34
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:7 
寫直觀代碼好過用晦澀難懂的算符

授人以渔,不授人以鱼。
2013-05-19 09:42
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
程序代码:
int toint(char *str)
{
    int sum = 0;
    char *p = str;
    
    while ('\0' != *p)
    {
        sum += *p - '0';
        sum <<= 1, p++;
    }
    return sum;
}


[fly]存在即是合理[/fly]
2013-05-19 11:47
Ryker
Rank: 6Rank: 6
等 级:侠之大者
威 望:1
帖 子:145
专家分:420
注 册:2013-2-19
收藏
得分:0 
以下是引用azzbcc在2013-5-19 11:47:32的发言:

int toint(char *str)
{
    int sum = 0;
    char *p = str;
   
    while ('\0' != *p)
    {
        sum += *p - '0';
        sum <<= 1, p++;
    }
    return sum;
}


虽然能看明白..但是写不出来...
2013-05-19 16:04
scrooper
Rank: 2
来 自:杭州
等 级:论坛游民
帖 子:13
专家分:21
注 册:2012-7-10
收藏
得分:0 
以下是引用azzbcc在2013-5-19 11:47:32的发言:

int toint(char *str)
{
    int sum = 0;
    char *p = str;
     
    while ('\0' != *p)
    {
        sum += *p - '0';
        sum <<= 1, p++;
    }
    return sum;
}
貌似while循环里面有两句反了,应该先移位在做加减
2013-05-19 20:41
快速回复:学到了位运算...有点晕了...
数据加载中...
 
   



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

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