zoukankan      html  css  js  c++  java
  • PAT 甲级 1010 Radix

    #include <cstdio>
    #include <cstring>
    #include <cctype>
    #include <algorithm>
    using namespace std;
    typedef long long LL;
    struct bign
    {
        int len;
        int d[30];
        bign()
        {
            len=0;
            memset(d,0,sizeof(d));
        }
    };
    bign change(char str[],int &q)//将读入的字符串每一位保存进结构体相同下标的int数组里,并确定最小进制(即数串长度+1)
    {
        q=1;
        bign a;
        a.len=strlen(str);
        for(int i=a.len-1;i>=0;--i)
        {
            if(isdigit(str[i]))
            {
                a.d[a.len-1-i]=str[i]-'0';
    
            }
            else
            {//将字母转换10进制,a-10,b-11。。。
                a.d[a.len-1-i]=str[i]-'a'+10;
            }
            q=q>a.d[a.len-1-i]?q:a.d[a.len-1-i];
        }
        ++q;
        return a;
    }
    LL transform(bign a,int r)//将r进制的数转化并返回10进制
    {
        LL ans=0,p=1;
        for(int i=0;i<a.len;++i)
        {
            ans+=a.d[i]*p;
            p*=r;
        }
        return ans;
    }
    int binary_search(LL low,LL high,LL answer,bign a)
    {
        while(low<=high)
        {
            LL mid=(low+high)/2;
            LL res=transform(a,mid);
            if(res==answer)
                return mid;
            else if(res>answer||res<0)
                high=mid-1;
            else
                low=mid+1;
        }
        return -1;
    }
    
    int main()
    {//r1,r2分别代表对应数串最小进制
        int n,tag,radix,r1,r2;
        char a[20],b[20];
        scanf("%s %s %d %d",a,b,&tag,&radix);
        bign a1=change(a,r1);
        bign b1=change(b,r2);
        int ans;
        if(tag==1)
        {
            LL x=transform(a1,radix);
            LL l=r2;
            LL h=max(x,(LL)r2);
            ans=binary_search(l,h,x,b1);
        }
        else
        {
            LL x=transform(b1,radix);
            LL l=r1;
            LL h=max(x,(LL)r1);
            ans=binary_search(l,h,x,a1);
        }
        if(ans==-1)
            printf("Impossible
    ");
        else
            printf("%d
    ",ans);
        return 0;
    }
    View Code

    转载https://blog.csdn.net/a845717607/article/details/86531915

  • 相关阅读:
    关于如何Debug进MVC3源代码
    浏览文件按钮
    C#多线程学习(五) 多线程的自动管理(定时器)
    记录总数
    Json对象格式化字符串输出
    数据与通信之WebRequest.Web
    ASP.NET MVC3中的ViewBag动态性
    SQL Server 2005的XML数据修改语言(XML DML)
    SOCKET与TCP/IP与HTTP的关系
    WPF绑定方式
  • 原文地址:https://www.cnblogs.com/jeseesmith/p/13936347.html
Copyright © 2011-2022 走看看