进制转换(jinzhi.pas,jinzhi.c,jinzhi.cpp) pascal

问题描述给出一个P进制整数N,求N的Q进制表示。期中0<=N<=32767,2<=P<=16,2<=Q<=16。大于9的数字用A、B、C、D、E、F表示。输入:PQN(用... 问题描述
给出一个 P 进制整数 N,求 N 的 Q 进制表示。期中 0<= N <= 32767 , 2 <= P <= 16, 2 <= Q <= 16。大于 9 的数字用 A、B、C、D、E、F 表示。
输入:
P Q
N(用 P 进制表示的)
输出:
N(用 Q 进制表示的)
样例
输入:
5 16
421
输出:
6F
展开
 我来答
百度网友1cb4e71
2009-10-12 · TA获得超过400个赞
知道小有建树答主
回答量:100
采纳率:0%
帮助的人:174万
展开全部
var
st:string;
x,i,j,p,q:integer;
s:longint;
a:array[1..16] of integer;
begin
readln(p,q);
readln(st);
s:=0;
for i:=length(st) downto 1 do
begin
if (st[i]>='0') and (st[i]<='9') then
x:=ord(st[i])-48
else
x:=ord(st[i])-55;
s:=s*p+x;
end;
i:=0;
while s>0 do
begin
i:=i+1;
a[i]:=s mod q;
s:=s div q;
end;
for j:=i downto 1 do
if a[j]>9 then write(chr(a[j]+55)) else write(a[j]);
writeln;
end.
dengkehao
2009-10-13 · TA获得超过913个赞
知道小有建树答主
回答量:302
采纳率:0%
帮助的人:263万
展开全部
var i,m,n,v,t:longint;ch:char;num:string;
begin
assign(input,'change.in');reset(input);
assign(output,'change.out');rewrite(output);
readln(n);readln(num);readln(m);v:=0;
for i:=1 to length(num) do begin
case num[i] of
'0': t:=0;
'1': t:=1;
'2': t:=2;
'3': t:=3;
'4': t:=4;
'5': t:=5;
'6': t:=6;
'7': t:=7;
'8': t:=8;
'9': t:=9;
'A': t:=10;
'B': t:=11;
'C': t:=12;
'D': t:=13;
'E': t:=14;
'F': t:=15
end;
v:=v*n+t;end;
num:='';
while v<>0 do begin
case v mod m of
0:ch:='0';
1:ch:='1';
2:ch:='2';
3:ch:='3';
4:ch:='4';
5:ch:='5';
6:ch:='6';
7:ch:='7';
8:ch:='8';
9:ch:='9';
10:ch:='A';
11:ch:='B';
12:ch:='C';
13:ch:='D';
14:ch:='E';
15:ch:='F'
end;
num:=ch+num;v:=v div m;end;
writeln(num);close(input);close(output);
end.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式