[参考]用递归的方法获取 字符 对应的 二进制字符串 (C/C++)

将字符转换为16进制字符串、十进制字符串可以参考这里:https://www.cnblogs.com/stxs/p/8846545.html

代码及调试结果

举例:字符'a',它对应的ASCII码为0011 0110,没错我就是要在屏幕上输出0011 0110!!!

具体的代码贴在下面,注释写的很清楚,需要的话可以仔细研究一下。

#include<iostream>
#include<stdlib.h>
using namespace std;
// 核心函数
// ch:传入的字符; n:n*2对应对了当前ch的进制数,初始值选为16。
// m:指针,用于索引数组,初始值为0; out_bin[]:输出的二进制字符串
void Char2Bin(unsigned char ch,int n, int *m, unsigned char out_bin[]){
    if (n>4){
        // 当前的ch将变为16位的二进制,之后将变成4位的二进制,所以 n/4(16/4)
        Char2Bin(ch/n,n/4,m,out_bin);
        Char2Bin(ch%n,n/4,m,out_bin);
    }
    else if (n>2){
        // 当前的ch将变为4位的二进制,之后将变成2位的二进制,所以 n/2(4/2)
        Char2Bin(ch/n,n/2,m,out_bin);
        Char2Bin(ch%n,n/2,m,out_bin);
    }
    else{
        // 当前ch是2位的二进制,只需将其转化为0和1即可
        out_bin[(*m)++] = ch/2 + '0';
        out_bin[(*m)++] = ch%2 + '0';
        return;    // 到这里必须返回,否则都会运行最后一行再返回,造成冗余
    }
    out_bin[8] = '\0'; // 字符数组最后以'\0'结尾就会变成字符串,
    // 可以参考 http://www.runoob.com/cplusplus/cpp-strings.html
}

// 调试部分
void main (){
    unsigned char out[9];
    int m = 0;
    Char2Bin('a',16,&m,out); // 当前ch是32位的二进制
    cout << out << endl;
    system("pause");
}

输出结果:

猜你喜欢

转载自www.cnblogs.com/stxs/p/9222421.html