小X和数字(中石油20训练赛NO.9)

自从小 X 研究出了 BetaGo 之后, 他发现数学是一门 很重要的学科,在解决实际问题的时候经常会要用到一些数学知识。 导致小 X 最近对数和数字比较感兴趣,而他喜欢把数拆成一位一位的数字来看, 例如712839 在小 X 眼中就是 1, 2, 3, 7, 8,9 六个数字。
小 X 发现了一种完美数: 如果在一个数中, 1~9 这 9 种数字都出现至少一次, 例如 84376521931 这个数就很完美了。而如果缺了 1~9 中的某一种时, 这个数就不太完美, 例如 712839 中就缺了 4, 5, 6 三种数字
但是小 X 发现 1~9 全出现在一个数中时, 这个数会非常大。为了避免这种情况,小 X 想了一个好办法,那就是判断一个数 n 是否完美时,不仅仅看这个数 n 本身是否包含 1~9 这 9 种数字,同时去看这个数的倍数。也就是说如果这个数 n 不完美,那就看 n 和 2n 两个数中是否包含了 1~9 这 9 种数字。如果还是没有,那就再看 n, 2n, 3n 三个数中是否包含了 1~9 这 9 种数字,以此类推。
例如当 n = 712839 时, 这个数只包含了 1, 2, 3, 7, 8,9,所以并不完美
2× n = 1425678,那么 n 中包含了 1, 2, 3, 7, 8,9,而 2× n 中又包含了 1, 2, 4, 5, 6, 7, 8,所以当我们数到 2× n 时这个数就完美了
小 X 想知道对于任意一个从键盘输入的数 n, 需要数到多少时, 这个数才完美。小 X 自己并不知道答案, 但是他想到了你,想请你来帮他解决这个问题。

输入
输入数据仅有一行包含一个正整数 n, 表示小 X 想知道这个数 n 需要数到多少时才完美。

输出
输出一行仅有一个数ans, 表示需要数到ans这个数才完美, ans = k× n(k为正整数)。

样例输入:
1

样例输出:
9

#include<bits/stdc++.h>
using namespace std;
int k[1000],t[10],w,c=1,n,i,ss;

int main()
{
    cin>>n;
    k[1]=n;
    i=1;
    w=i;
    while (k[i]/10>=1)
    {
        k[i+1]=k[i]/10;
        k[i]=k[i]%10;
        i+=1;
        w=i;
        }
    while (1)
    {
        for (i=1;i<=9;i++)
        {
            for (int j=1;j<=w;j++)
            {
                if (k[j]==i)
                {
                    t[i]=1;
                    break;
                }
            }
        }
        for (int kkk=1;kkk<=9;kkk++)
        {
         if (t[kkk]!=1)break;
         if (kkk==9)
         {
          for (int ii=w;ii>=1;ii--)
          {
           cout<<k[ii];
          }
          cout<<endl;
          return 0;
         }
        }
        c+=1;
        k[1]+=n;
        i=1;
     while (k[i]/10>=1)
     {
      k[i+1]+=k[i]/10;
      k[i]=k[i]%10;
      i+=1;
      if (i>w)w=i;
        }
    }
    return 0;
}

转载于:https://www.cnblogs.com/leonqqs/p/7083851.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值