程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> URAL 1233 - Amusing Numbers

URAL 1233 - Amusing Numbers

編輯:C++入門知識

首先計算出k至少為第幾位,如果m小於這個數,那麼輸出0

還有一種情況, 就是10的i次方的這種情況,如果i+1等於m,那麼直接輸出k,否則輸出0

其他的情況,就是二分,然後判斷計算其插入到k之前的數的個數與k至少的位數之和

 

#include <stdio.h>   
#include <math.h>   
#define LL unsigned long long   
  
LL d[20],k,m,s;  
int t;  
void init()  
{  
    d[0]=1;  
    for(int i=1;i<20;i++)  
        d[i]=d[i-1]*10;  
}  
  
int check(LL x)  
{  
    int t=log10(x)+1;  
    if(x/d[t-1]==1&&x%d[t-1]==0&&t<m)return 1;  
    return 0;  
}  
  
LL pre(LL x)  
{  
    LL ans=0;  
    for(int i=0;i<t;i++)  
    {  
        ans+=(x/d[t-1-i]-d[i]+1);  
    }  
    return ans;  
}  
  
LL f(LL x,LL y)  
{  
    LL ans=s;  
    int p=log10(y)+1;  
    for(int i=t+1;i<=p;i++)  
    {  
        if(i<p)  
            ans+=x*d[i-t]-d[i-1];  
        else  
        {  
            if(x*d[i-t]-d[p-1]>y-d[p-1]){ans+=y-d[p-1];}  
            else {ans+=x*d[i-t]-d[p-1];}  
        }  
    }  
    return ans;  
}  
  
int main()  
{  
    scanf("%I64u%I64u",&k,&m);  
    init();  
    t=log10(k)+1;  
    s=pre(k);  
    if(m<s)  
    {  
        printf("0\n");  
    }  
    else  
    {  
        if(check(k))printf("0\n");  
        else  
        {  
            LL l=k,r=1LL<<63,mid=(l+r)/2;  
            while(l<r)  
            {  
                if(f(k,mid)<m) l=mid+1;  
                else r=mid;  
                mid=(l+r)/2;  
            }  
            if(mid==k)  
            printf("%I64u\n",mid);  
            else  
            printf("%I64u\n",mid-1);  
        }  
    }  
    return 0;  
}  

#include <stdio.h>
#include <math.h>
#define LL unsigned long long

LL d[20],k,m,s;
int t;
void init()
{
    d[0]=1;
    for(int i=1;i<20;i++)
        d[i]=d[i-1]*10;
}

int check(LL x)
{
    int t=log10(x)+1;
    if(x/d[t-1]==1&&x%d[t-1]==0&&t<m)return 1;
    return 0;
}

LL pre(LL x)
{
    LL ans=0;
    for(int i=0;i<t;i++)
    {
        ans+=(x/d[t-1-i]-d[i]+1);
    }
    return ans;
}

LL f(LL x,LL y)
{
    LL ans=s;
    int p=log10(y)+1;
    for(int i=t+1;i<=p;i++)
    {
        if(i<p)
            ans+=x*d[i-t]-d[i-1];
        else
        {
            if(x*d[i-t]-d[p-1]>y-d[p-1]){ans+=y-d[p-1];}
            else {ans+=x*d[i-t]-d[p-1];}
        }
    }
    return ans;
}

int main()
{
    scanf("%I64u%I64u",&k,&m);
    init();
    t=log10(k)+1;
    s=pre(k);
    if(m<s)
    {
        printf("0\n");
    }
    else
    {
        if(check(k))printf("0\n");
        else
        {
            LL l=k,r=1LL<<63,mid=(l+r)/2;
            while(l<r)
            {
                if(f(k,mid)<m) l=mid+1;
                else r=mid;
                mid=(l+r)/2;
            }
            if(mid==k)
            printf("%I64u\n",mid);
            else
            printf("%I64u\n",mid-1);
        }
    }
    return 0;
}


 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved