蓝桥杯基础练习 十六进制转八进制C++

蓝桥杯基础练习 十六进制转八进制


蓝桥杯基础练习 十六进制转八进制C++_第1张图片
先将十六进制转二进制,再将二进制转八进制

#include<iostream>
using namespace std;

string trans(char a)//十六进制转二进制
{
	switch(a)
	{
		case'0':return "0000";
		case'1':return "0001";
		case'2':return "0010";
		case'3':return "0011";
		case'4':return "0100";
		case'5':return "0101";
		case'6':return "0110";
		case'7':return "0111";
		case'8':return "1000";
		case'9':return "1001";
		case'A':return "1010";
  		case'B':return "1011";
		case'C':return "1100";
		case'D':return "1101";
		case'E':return "1110";
		case'F':return "1111";
	}
}
int main()
{
	int n;
	string sixteen[10];//(1<=n<=10)
	cin>>n;
	for(int i=0;i<n;i++)
	{
		cin>>sixteen[i];
	}
	for(int i=0;i<n;i++)
	{
		string eight;
		string two;
		char eig;
		for(int j=0;j<sixteen[i].length();j++)
			two+=trans(sixteen[i][j]);					//调用函数十六进制字符串里的每个字符逐个转二进制
		int m=two.length()%3;							//一位八进制等于三位二进制
		if(m==1)two.insert(0,"00");						//如果余1在0位置插入两个0 (便于转换成八进制都凑成三位)
		else if(m==2)two.insert(0,"0");					//如果余2在0位置插入一个0
		if(!(two[0]=='0'&&two[1]=='0'&&two[2]=='0'))	//如果insert后的前三位不是都为0
		{
			eig=(two[0]-'0')*4+(two[1]-'0')*2+(two[2]);	 //4 2 1
			eight+=eig;									 //八进制字符串的第一个字符
		}
		for(int k=3;k<two.length();k+=3)
		{
			if(two.substr(k,3)=="000")eight+="0";		//提取k之后的三个字符(包括k) 
			else if(two.substr(k,3)=="001")eight+="1";
			else if(two.substr(k,3)=="010")eight+="2";
			else if(two.substr(k,3)=="011")eight+="3";
			else if(two.substr(k,3)=="100")eight+="4";
			else if(two.substr(k,3)=="101")eight+="5";
			else if(two.substr(k,3)=="110")eight+="6";
			else if(two.substr(k,3)=="111")eight+="7";
		}
		cout<<eight<<endl;
	}
	return 0;
}

因为刷不动题所以已经放手了…明天就比赛了,我佛了,就把之前写的都复习一下算了反正肯定都忘了
第二遍看正好再小结一下,这道题真的充分体现了string 的方便啊

二刷小结:

  • string sixteen[10]; 字符串数组可以很方便的取出每个字符串中的字符,sixteen[ i ][ j ]就是取出第i个字符串的第j个字符
  • 遍历数组用 str.length() 取数组的大小
  • str.insert(插入位置,要插入的字符串)
  • str.substr(k,n) 提取k之后的n个字符串
  • 一位八进制是三位二进制,一位十六进制是四位二进制 (也正是这道题的思路)

你可能感兴趣的:(蓝桥杯)