zoukankan      html  css  js  c++  java
  • ural 1104 && ural 1352

    题目:http://acm.timus.ru/problem.aspx?space=1&num=1352

    题意:首先定义梅森尼质数:符合 2 ^  p - 1是素数的数,现在给出一个 n 让你输出一个 p 满足 2 ^ p - 1 是第 n 个梅森尼质数 ( n < 39)

    打表的过的,就没什么可说的了

    View Code
     1 const int x[]={0,2,3,5,7,13,17,19,31,61,89,
     2                107,127,521,607,1279,2203,2281,3217,4253,4423,
     3             9689,9941,11213,19937,21701,23209,44497,86243,110503,132049,
     4         216091,756839,859433,1257787,1398269,2976221,3021377,6972593};
     5 int t,n;
     6 int main()
     7 {
     8     cin>>t;
     9     while (t--)
    10     {
    11         cin>>n;
    12         cout<<x[n]<<endl;
    13     }
    14     return 0;
    15 }

    题目:http://acm.timus.ru/problem.aspx?space=1&num=1104

    题意:给出一个 k 进制写的数,问是否存在一个 k可以满足把 给的 k 进制的数可以整除 (k - 1);

    发现 ural 里的discuss 真有意思,错了哪个样例,基本都可以在里面找到解决办法。以前好像做个这个题,觉得好熟悉,根据取余的性质 (a * b) % c = (a % c * b % c) % c;

    View Code
     1 const int N = 1000001;
     2 char str[N];
     3 int a[N];
     4 int main()
     5 {
     6     int i,j;
     7     //freopen("data.txt","r",stdin);
     8     while(cin>>str)
     9     {
    10         int len = strlen(str);
    11         int tem = 0;
    12         for(i = 0; i < len; i++)
    13         {
    14             if(str[i] >= 'A' && str[i] <= 'Z')
    15             a[i] = (str[i] - 'A' + 10);
    16             else a[i] = str[i] - '0';
    17             tem = Max(a[i],tem);
    18         }
    19         if(tem < 2) {printf("2\n");continue;}  // 注意这里,如果不写,会在第 7 个样例 crash(我的是这样的)
    20         int kem;
    21         for(i = tem + 1; i <= 36; i++)  // 这里 符合题意的最小 k 一定要比给的进制里最大的还要大
    22         {
    23             kem = 0;
    24             for(j = 0; j < len; j++)
    25             {
    26                 kem = kem * i + a[j];
    27                 kem %= (i - 1);
    28             }
    29             if(!kem) break;
    30         }
    31         if(!kem) printf("%d\n",i);
    32         else printf("No solution.\n");
    33     }
    34     return 0;
    35 }
  • 相关阅读:
    7-25 念数字
    7-24 约分最简分式
    7-23 币值转换
    HDU-1102-Constructing Roads
    HDU-1301-Jungle Roads
    链式向前星
    HDU-1217-Arbitrage(SPFA)
    POJ-1258-Agri-Net
    HDU-1863-畅通工程
    POJ-3050-Hoscotch
  • 原文地址:https://www.cnblogs.com/fxh19911107/p/2678449.html
Copyright © 2011-2022 走看看