一、题目描述
字节有几位都没个标准,古代程序员过的什么日子啊?还好现在字节统一成8位了。
鉴于我对C++已有相当牢固的基础,可以探索底层开发了,先做个解析十六进制字节数据的功能吧。
输入规格
- 每项待读入的字节数据由两个非空白字符构成。
- 如是正常的十六进制字节数据,高位在前、低位在后。
- 不区分大小写。
- 各项之间由数量不定的空白符隔开。直接用
cin
读入即可,无需特殊处理。
输出规格
- 每行输出一项:先输出读入的字符,间隔冒号和空格,再按十进制输出字节的数值。
样例输入
0A a3
Ff +z
样例输出
0A: 10
a3: 163
Ff: 255
+z: invalid
样例解释
0A: 0 * 16 + 10 * 1 = 10
a3: 10 * 16 + 3 * 1 = 163
Ff: 15 * 16 + 15 * 1 = 255
+z
含无效字符。
提示:后续题目用到类似功能,设计时请考虑重用性。
代码框架
#include <iostream>
using namespace std;
unsigned char parse_byte(unsigned char hi, unsigned char lo){
return 0; // TODO
}
int main() {
for(char hi, lo; cin >> hi >> lo;){
cout << hi << lo << ": ";
if(is_hex(hi) && is_hex(lo)){ // 重用
cout << (int)parse_byte(hi, lo) << endl;
}else{
cout << "invalid" << endl;
}
}
}
二、完整C++代码实现
#include <iostream>
using namespace std;
unsigned char parse_byte(unsigned char hi, unsigned char lo){
if(hi>='0'&&hi<='9'){
hi=hi-'0';
}else if(hi>='a'&&hi<='f'){
hi=hi-'a'+10;
}else if(hi>='A'&&hi<='f'){
hi=hi-'A'+10;
}
if(lo>='0'&&lo<='9'){
lo=lo-'0';
}else if(lo>='a'&&lo<='f'){
lo=lo-'a'+10;
}else if(lo>='A'&&lo<='f'){
lo=lo-'A'+10;
}
return hi*16+lo; // TODO
}
bool is_hex(char c){
if((c>='0'&&c<='9')||(c>='a'&&c<='f')||(c>='A'&&c<='F')){
return true;
}else{
return false;
}
}
int main() {
for(char hi, lo; cin >> hi >> lo;){
cout << hi << lo << ": ";
if(is_hex(hi) && is_hex(lo)){ // 重用
cout << (int)parse_byte(hi, lo) << endl;
}else{
cout << "invalid" << endl;
}
}
}
三、测评详情
四、总结反思
hi和lo的高位低位转为十进制数的时候首先要对字符范围进行判断
a-f:hi=hi-'a'+10
A-Z:hi=hi-'A'+10
0-9:hi=hi-'0'!!!!这一步一定不要忘了
因为0的ascii码为48,就是要是字符直接加减法运算会默认用ascii码的值与整型进行加减
类型转换:因为char范围比int小可以直接隐式转换