C++如何将十六进制字符串转换为二进制字符串
更新时间:2023年08月02日 08:35:59 作者:花好约猿上王者
这篇文章主要介绍了C++如何将十六进制字符串转换为二进制字符串问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
十六进制字符串转换为二进制字符串
一种简单的方法将十六进制字符串转为二进制字符串,不限制十六进制的字节数。
源代码
传入的十六进制字符串需要转换为大写!(%X, toupper())。
string GetBinaryStringFromHexString (string strHex) { string sReturn = ""; unsigned int len = strHex.length(); for (unsigned int i = 0; i<len; i++) { switch ( strHex[i]) { case '0': sReturn.append ("0000"); break; case '1': sReturn.append ("0001"); break; case '2': sReturn.append ("0010"); break; case '3': sReturn.append ("0011"); break; case '4': sReturn.append ("0100"); break; case '5': sReturn.append ("0101"); break; case '6': sReturn.append ("0110"); break; case '7': sReturn.append ("0111"); break; case '8': sReturn.append ("1000"); break; case '9': sReturn.append ("1001"); break; case 'A': sReturn.append ("1010"); break; case 'B': sReturn.append ("1011"); break; case 'C': sReturn.append ("1100"); break; case 'D': sReturn.append ("1101"); break; case 'E': sReturn.append ("1110"); break; case 'F': sReturn.append ("1111"); break; } } return sReturn; }
十六进制字符串转二进制字符串1的个数
优化版
建立十六进制字符串 字符“0-F” 对应二进制中1的个数的映射数组
代码如下:
#include<iostream> #include<string> using namespace std; int main(){ string inputHex; cin >> inputHex; int bitOneNumber[16] = {0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; inputHex = inputHex.substr(2); int cnt = 0; for(auto ch : inputHex){ if(ch >= '0' && ch <= '9') cnt += bitOneNumber[ch - '0']; else if(ch >= 'a' && ch <= 'f') cnt += bitOneNumber[ch - 'a' + 10]; else return -1; } cout << cnt << endl; system("pause"); return 0; }
十六进制字符串转为二进制字符串
遍历统计1的个数
#include<iostream> #include<string> using namespace std; string HexStrToBinStr(string& inputHex){ string binStr; for(auto ch : inputHex){ switch (ch) { case '0' : binStr += "0000"; break; case '1' : binStr += "0001"; break; case '2' : binStr += "0010"; break; case '3' : binStr += "0011"; break; case '4' : binStr += "0100"; break; case '5' : binStr += "0101"; break; case '6' : binStr += "0110"; break; case '7' : binStr += "0111"; break; case '8' : binStr += "1000"; break; case '9' : binStr += "1001"; break; case 'a' : binStr += "1010"; break; case 'b' : binStr += "1011"; break; case 'c' : binStr += "1100"; break; case 'd' : binStr += "1101"; break; case 'e' : binStr += "1110"; break; case 'f' : binStr += "1111"; break; default: break; } } return binStr; } int main(){ string inputHex; cin >> inputHex; inputHex = inputHex.substr(2); string binStr = HexStrToBinStr(inputHex); int cnt = 0; for(auto ch : binStr) if(ch == '1') ++cnt; cout << cnt << endl; cout << binStr << endl; system("pause"); return 0; }
二进制字符串转十进制字符串
#include<iostream> #include<string> using namespace std; //十六进制字符串串转二进制 string HexStrToBinStr(string& inputHex){ string binStr; for(auto ch : inputHex){ switch (ch) { case '0' : binStr += "0000"; break; case '1' : binStr += "0001"; break; case '2' : binStr += "0010"; break; case '3' : binStr += "0011"; break; case '4' : binStr += "0100"; break; case '5' : binStr += "0101"; break; case '6' : binStr += "0110"; break; case '7' : binStr += "0111"; break; case '8' : binStr += "1000"; break; case '9' : binStr += "1001"; break; case 'a' : binStr += "1010"; break; case 'b' : binStr += "1011"; break; case 'c' : binStr += "1100"; break; case 'd' : binStr += "1101"; break; case 'e' : binStr += "1110"; break; case 'f' : binStr += "1111"; break; default: break; } } return binStr; } //二进制转十进制 struct decStr{ int len; char decstr[100000]; decStr() : len(0){ for(int i = 0; i < 100000; ++i) decstr[i] = 0; } }; void addCurNumToDecStr(decStr& data, int num){ for(int i = 0; i < data.len; ++i) data.decstr[i] *= 2; data.decstr[0] += num; for(int i = 0; i < data.len; ++i){ data.decstr[i + 1] += data.decstr[i] / 10; data.decstr[i] %= 10; } if(data.decstr[data.len] != 0) ++data.len; } string assicTostr(decStr&data){ string decstr; for(int i = data.len - 1; i >= 0; --i){ decstr += data.decstr[i] + '0'; } return decstr; } string BinStrToDecStr(string& binStr){ decStr data; for(int i = 0; i < binStr.size(); ++i){ addCurNumToDecStr(data, binStr[i] == '1' ? 1 : 0); } string decstr = assicTostr(data); return decstr; } int main(){ string inputHex; cin >> inputHex; inputHex = inputHex.substr(2); string binStr = HexStrToBinStr(inputHex); int cnt = 0; for(auto ch : binStr) if(ch == '1') ++cnt; cout << cnt << endl; cout << binStr << endl; string decstr = BinStrToDecStr(binStr); cout << decstr << endl; system("pause"); return 0; }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
最新评论