进制转换(Q进制转换成T进制)详解版

题目:

给定一个整数Q(2<=Q<=10),一个非空字符串,以及另一个整数T(2<=T<=10), 编程要求过滤掉字符串中所有非Q进制数对应的字符组成一个新的字符串,该字符串无正负号,将该字符串表示的Q进制数转换为T进制数的字符串输出。

输入格式:

第一行输入一个整数Q, 代表Q进制(2<=Q<=10)

第二行输入以回车结束的一行非空字符串。

第三行输入一个整数T, 代表要转换成T进制

输出格式:

输出转换后的T进制数字符串。

输入样例:

10
15
2

输出样例:

1111

思路:

首先读入一个Q进制的数,根据进制的转换,我们可以把它换成十进制的数字(但是这里记得是×q,而不是×10,后面测试的时候发现了这个问题)切换之后,再把这个十进制的数字换成T进制,就是依次除以T,取它的余数,最后倒过来输出即可(因此这里用栈也可以,先进后出)

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
/*
第一行输入一个整数Q, 代表Q进制(2<=Q<=10)

第二行输入以回车结束的一行非空字符串。

第三行输入一个整数T, 代表要转换成T进制
*/
int main()
{
	ll q, t, sum = 0;
	char ch;
	scanf("%lld", &q);
	//读取换行符
	getchar();
	//计算这个数字有多大
	while ((ch = getchar()) != '\n')
	{
		if (ch >= '0' && ch <= '0' + q - 1)
		{
			sum = sum * q + (ch - '0');
		}
	}
	//进行切换进制
	scanf("%lld", &t);
	vector<ll>vec;
	//int yu;
	for (int i = sum; i != 0;)
	{
		vec.push_back(i % t);
		i = i / t;
	}
	for (int i = vec.size() - 1; i >= 0; --i)
	{
		cout << vec[i];
	}


	return 0;
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#include using namespace std; int main() { cout<<"06209527 朱**的作业!"<<endl; char arr[33],arr1[50]; //数组arr用来保存用户输入的整形数 int b=0; int base; //base用来保存用户欲转换的进制基数 int len; //衡量arr的长度 double sum=0,a=0; //sum是用户输入的浮点数大小 cout<<"请输入一个浮点型整数的小数部分"<>arr; len=strlen(arr); for(int i=0;i<len;i++) { a=arr[i]-'0'; for(int j=-1;j<i;j++) a=a/10; sum+=a; } cout<<"您输入的浮点型小数是:"<<sum<<endl; cout<<"请输入你要转换的进制(大于0,小于36!)"<>base; if(base36) { cout<<"输入错误!请重新输入!"<<endl; } int n=0; while(sum!=0&&n0) sum=sum-b; n++; } cout<<"转换后的小数为:"<<endl; cout<<"0."; arr1[n]=0; len=strlen(arr1); for(i=0;i57) //9的ASCII码为57 { switch(arr1[i]) { case 58:cout<<"A";break; case 59:cout<<"B";break; case 60:cout<<"C";break; case 61:cout<<"D";break; case 62:cout<<"E";break; case 63:cout<<"F";break; case 64:cout<<"G";break; case 65:cout<<"H";break; case 66:cout<<"I";break; case 67:cout<<"J";break; case 68:cout<<"K";break; case 69:cout<<"L";break; case 70:cout<<"M";break; case 71:cout<<"N";break; case 72:cout<<"O";break; case 73:cout<<"P";break; case 74:cout<<"Q";break; case 75:cout<<"R";break; case 76:cout<<"S";break; case 77:cout<<"T";break; case 78:cout<<"U";break; case 79:cout<<"V";break; case 80:cout<<"W";break; case 81:cout<<"X";break; case 82:cout<<"Y";break; case 83:cout<<"Z";break; } } else cout<<arr1[i]; } return 0; }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值