鱼C论坛

 找回密码
 立即注册
查看: 2291|回复: 4

[已解决]十进制转化二进制

[复制链接]
发表于 2018-2-6 03:16:27 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
老师让我们写个程序十进制转换二进制,要用到switch 和 case语句,我写了一个运行的很好,但总感觉太繁杂了。请问我这样写有办法化简不?
#include <iostream>
using namespace std;
void binaire(int n, int &n1,int &n2,int &n3,int &n4,int &n5,int &n6,int &n7,int &n8);

int main()
{
    int n;
    cout<<"n?";
    cin >> n;
    int n1,n2,n3,n4,n5,n6,n7,n8;
    binaire(n,n1,n2,n3,n4,n5,n6,n7,n8);
    cout<<n1<<n2<<n3<<n4<<n5<<n6<<n7<<n8<<endl;
}
void binaire(int n, int &n1,int &n2,int &n3,int &n4,int &n5,int &n6,int &n7,int &n8)
{
        switch (n%2)
        {
                case 1:
                        n8=1;
                        n/=2;
                        break;
                case 0:
                        n8=0;
                        n/=2;
                        break;
        }
        switch (n%2)
        {
                case 1:
                        n7=1;
                        n/=2;
                        break;
                case 0:
                        n7=0;
                        n/=2;
                        break;
        }
        switch (n%2)
        {
                case 1:
                        n6=1;
                        n/=2;
                        break;
                case 0:
                        n6=0;
                        n/=2;
                        break;
        }
        switch (n%2)
        {
                case 1:
                        n5=1;
                        n/=2;
                        break;
                case 0:
                        n5=0;
                        n/=2;
                        break;
        }
        switch (n%2)
        {
                case 1:
                        n4=1;
                        n/=2;
                        break;
                case 0:
                        n4=0;
                        n/=2;
                        break;
        }
        switch (n%2)
        {
                case 1:
                        n3=1;
                        n/=2;
                        break;
                case 0:
                        n3=0;
                        n/=2;
                        break;
        }
        switch (n%2)
        {
                case 1:
                        n2=1;
                        n/=2;
                        break;
                case 0:
                        n2=0;
                        n/=2;
                        break;
        }
        switch (n%2)
        {
                case 1:
                        n1=1;
                        n/=2;
                        break;
                case 0:
                        n1=0;
                        n/=2;
                        break;
        }
}
最佳答案
2018-2-6 14:30:35
好吧,改一下第一个,这次的确有使用switch case 哦,那位老师的本意应该是这个吧 ^_^
#include <iostream>
#include <string>

std::string binaire(uint64_t val, uint8_t length)
{
        std::string bin;
        uint64_t mask;

        switch(length)
        {
        case sizeof(uint8_t):
                mask = 0x80;
                break;
        case sizeof(uint16_t) :
                mask = 0x8000;
                break;
        case sizeof(uint32_t) :
                mask = 0x80000000;
                break;
        case sizeof(uint64_t) :
                mask = 0x8000000000000000;
                break;
        default:
                throw "参数 length 错误!";
        }


        for( ; mask != 0; mask >>= 1)
        {
                if(mask & val)
                        bin.append("1");
                else
                        bin.append("0");
        }

        return bin;
}

int main(void)
{
        uint8_t val8 = 100;
        uint16_t val16 = 0xFF00;
        uint32_t val32 = 0xAA55AA55;
        uint64_t val64 = 0xAA55AA55FFFF0000;

        std::cout << binaire(val8, sizeof(val8)) << std::endl;
        std::cout << binaire(val16, sizeof(val16)) << std::endl;
        std::cout << binaire(val32, sizeof(val32)) << std::endl;
        std::cout << binaire(val64, sizeof(val64)) << std::endl;

        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-2-6 05:22:30 | 显示全部楼层
这是哪个老师出的题目?
用switch case 来进制转换?

我写了两个版本的,没有一个是用 switch case 的,因为我真的不知道该如何用 ^_^
#include <iostream>
#include <string>

std::string binaire(uint32_t val)
{
        std::string bin;

        for(uint32_t mask = 0x80000000; mask != 0; mask >>= 1)
        {
                if(mask & val)
                        bin.append("1");
                else
                        bin.append("0");
        }

        return bin;
}

int main(void)
{
        std::cout << binaire(0xAA55AA55) << std::endl;
        std::cout << binaire(100) << std::endl;                // 其实无论是十进制100,还是十六进制0xAA55AA55,都无所谓
        return 0;
}
#include <iostream>
#include <string>

void binaire(uint32_t val)
{
        std::string bin;

        while(val)
        {
                if(val % 2)
                        bin.append("1");
                else
                        bin.append("0");

                val /= 2;
        }

        for(auto r_iter = bin.rbegin(); r_iter != bin.rend(); ++r_iter)
                std::cout << *r_iter;
        std::cout << std::endl;
}

int main(void)
{
        binaire(100);
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-6 05:30:16 | 显示全部楼层
第二个改一下吧
#include <iostream>
#include <string>

std::string binaire(uint32_t val)
{
        std::string bin;

        while(val)
        {
                if(val % 2)
                        bin.insert(bin.begin(), '1');
                else
                        bin.insert(bin.begin(), '0');

                val /= 2;
        }

        return bin;
}

int main(void)
{
        std::cout << binaire(100) << std::endl;
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-6 14:30:35 | 显示全部楼层    本楼为最佳答案   
好吧,改一下第一个,这次的确有使用switch case 哦,那位老师的本意应该是这个吧 ^_^
#include <iostream>
#include <string>

std::string binaire(uint64_t val, uint8_t length)
{
        std::string bin;
        uint64_t mask;

        switch(length)
        {
        case sizeof(uint8_t):
                mask = 0x80;
                break;
        case sizeof(uint16_t) :
                mask = 0x8000;
                break;
        case sizeof(uint32_t) :
                mask = 0x80000000;
                break;
        case sizeof(uint64_t) :
                mask = 0x8000000000000000;
                break;
        default:
                throw "参数 length 错误!";
        }


        for( ; mask != 0; mask >>= 1)
        {
                if(mask & val)
                        bin.append("1");
                else
                        bin.append("0");
        }

        return bin;
}

int main(void)
{
        uint8_t val8 = 100;
        uint16_t val16 = 0xFF00;
        uint32_t val32 = 0xAA55AA55;
        uint64_t val64 = 0xAA55AA55FFFF0000;

        std::cout << binaire(val8, sizeof(val8)) << std::endl;
        std::cout << binaire(val16, sizeof(val16)) << std::endl;
        std::cout << binaire(val32, sizeof(val32)) << std::endl;
        std::cout << binaire(val64, sizeof(val64)) << std::endl;

        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-2-7 21:38:50 | 显示全部楼层
人造人 发表于 2018-2-6 14:30
好吧,改一下第一个,这次的确有使用switch case 哦,那位老师的本意应该是这个吧 ^_^

谢谢啦 就是这样的!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-1 12:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表