最新公告
  • 欢迎您光临信息学奥赛网,一个优质的信息学编程题库和信息学编程学习资源专业网站。欢迎加入VIP
  • 确定进制

    正文概述 陈老师   2026-01-20 15:38:58  

    题目描述

    69=426*9=42对于十进制来说是错误的,但是对于13进制来说是正确的。即, 6(13)9(13)=42(13)6_{(13)}*9_{(13)}= 42_{(13)}, 而 42(13)=4131+2130=54(10)42_{(13)}=4*13^1+2*13^0=54_{(10)}

    你的任务是写一段程序,读入三个整数ppqqrr,然后确定一个进制 B(2B40)B(2≤B≤40) 使得 pq=rp*q=r。 如果 BB 有很多选择, 输出最小的一个。

    例如:p=11,q=11,r=121p=11, q=11, r=121.则有11(3)11(3)=121(3)11_{(3)}* 11_{(3)}= 121_{(3)}因为11(3)=131+130=4(10)11_{(3)}= 1 * 3^1+ 1 * 3^0= 4_{(10)}121(3)=132+231+130=16(10)121_{(3)}=1*3^2+2*3^1+1*3^0=16_{(10)}。对于进制 10,同样有11(10)11(10)=121(10)11_{(10)}* 11_{(10)}= 121_{(10)}。这种情况下,应该输出 33。如果没有合适的进制,则输出 00

    输入格式

    一行,包含三个整数pqrp、q、r

    pqrp、q、r所有位都是数字,并且1pqr1,000,0001 ≤ p、q、r ≤ 1,000,000

    输出格式

    一个整数:即使得p*q=r成立的最小的B。如果没有合适的B,则输出0。

    6 9 42
    
    13
    
    2 2 4
    
    5
    
    信息学奥赛网,一个优质的信息学奥赛学习资源平台!
    信息学奥赛网 » 确定进制