| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 320 人关注过本帖
标题:二进制转换问题
只看楼主 加入收藏
糯米团小颖
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2012-3-17
结帖率:0
收藏
已结贴  问题点数:20 回复次数:2 
二进制转换问题
“转换二进制”;这是我做的,运行时总是负数,我已经看不清楚了,大家帮我看看吧,改一改,谢谢啦~~~


#include<iostream>
#include<fstream>
#include<sstream>
#include<vector>
#include<cmath>
using namespace std;
//---------------------------------------------------
int main()
{
 cout<<"输入要转换的二进制数 : "<<endl;
 string s;
 vector<int> x;
 cin>>s;
 istringstream sin(s);
 int sum = 0;
 for(int a ;sin>>a;)
     x.push_back(a);
 int d=x.size();
 for(int i = 0; i<=d ;++i)
 {
  double o=pow(2.0,d-i);
  sum+=(x[i] * o);
 }
 cout<<sum<<endl;
 return 0;
}
搜索更多相关主题的帖子: double include 二进制 
2012-03-25 22:32
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9026
专家分:54030
注 册:2011-1-18
收藏
得分:20 
程序代码:
#include <iostream>
#include <sstream>
#include <vector>
using namespace std;

int main()
{
    cout<<"输入要转换的二进制数 : "<<endl;
    string s;
    cin >> s;

    vector<char> x;
    istringstream sin(s);
    for( char a ;sin>>a; )
        x.push_back(a);

    int sum = 0;
    size_t d = x.size();
    for( size_t i=0; i<d; ++i )
    {
        int o = 1<<(d-i-1);
        sum += (x[i]-'0') * o;
    }
    cout << sum << endl;

    return 0;
}

int main2()
{
    string s;
    cin >> s;

    int n = 0;
    for( size_t i=0; i<s.size(); ++i )
        n |= (s[i]-'0')<<(s.size()-i-1);

    cout << n << endl;

    return 0;
}

#include <bitset>
int main3()
{
    string s;
    cin >> s;

    std::bitset<sizeof(unsigned long)*8> x( s );
    unsigned long n = x.to_ulong();

    cout << n << endl;

    return 0;
}
2012-03-26 08:27
coleev
Rank: 2
来 自:四川,成都
等 级:论坛游民
帖 子:22
专家分:53
注 册:2010-9-9
收藏
得分:0 
#include <iostream>
using namespace std;
#include <stdlib.h>
int main()
{
    cout<<"**********\n十进制转二进制·练手**********\n(<=65535)\n";
    int D[16];
    D[0]=1;
    for(int i=0;i<16;i++)
    {
        D[i+1]=D[i]*2;
        cout<<D[i]<<endl;
    }
    cout<<"Please Type in an Integer(<65535):";
    int ta;cin>>ta;cout<<endl;
    int i=16;
    for(;i>=0;i--)
    {
        if(ta<D[i]) cout<<0;
        else if(ta>=D[i])
        {
            cout<<1;
            ta=ta-D[i];
        }
        if((i)%4==0) cout<<".";
    }
    cout<<endl;
    system("pause");
    return 0;
}

另一种思路 -
2012-06-16 13:37
快速回复:二进制转换问题
数据加载中...
 
   



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

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