且未

博客园 首页 新随笔 联系 订阅 管理

题目:

#include<stdio.h>
/*
   if(res >= base) return -1;
*/
int convert(int val,int base)//某进制转换为10进制
{
    int weight = 1,res,ans=0;
    while(val)
    {
        res  = val % 10;
        val = val / 10;
        if(res >= base) return -1;
        ans = ans + weight * res;
        weight = weight *base;
    }
    return ans;
}
int main()
{
    int p,q,r;
    int i,p1,q1,r1;
   scanf("%d%d%d",&p,&q,&r);
   for( i=2;i<=16;i++)
   {
        p1 = convert(p,i);
        if(p1<0) continue;
        q1 = convert(q,i);
        if(q1<0) continue;
        r1 = convert(r,i);
        if(r1<0) continue;
        if(p1*q1==r1) break;
   }
   if(i<17) printf("%d\n",i);
   else printf("0\n");
    return 0;
}

posted on 2018-05-01 17:22  阿聊  阅读(155)  评论(0)    收藏  举报