2016"百度之星"-资格赛-1001-A

原创 2016年05月30日 18:47:57
不是太会用markdown,这个题目也有些数学公式不好搞,所以直接给题目链接吧。
[题目](http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?cid=690&pid=1001)

这道题如果想要AC,需要用到逆元。这里,因为我们要求从x到y的每个字符的(ASCII 码值-28)的值的积(mod9973),所以需要把前缀积保存起来,最后用num[y]/num[x-1]%MOD,因为MOD是奇数,所以相当于num[y]*inv(num[x-1]) (mod p),也就是说,我们需要保存的是前缀积和前缀积对应的逆元就好了。这里我们可以进行一个0-9972逆元的一个预处理,能够节省很多时间,代码如下。
//逆元  ax ≡ 1(mod m)  此同余方程中x的最小正整数解叫做a mod m的逆元
//a与m互素的情况下,通常通过扩展欧几里得求逆元,但是这里的m:9973为素数,也可以使用费马小定理
//求得逆元为a^(m - 2)mod m
//a与m不互素时,转换一下公式求逆元:ans = a / b mod m = a mod (mb) / b

#include <stdio.h>
#include <string.h>
#define MOD 9973

char s[100010];
int num[100010];
int p[100010];
int res[10000];

//快速幂
int inv(int a, int b)   //b = MOD - 2
{
    int ans = 1;
    while (b)
    {
        if (b & 1)
        {
            ans = ans * a % MOD;
        }
        b >>= 1;
        a = a * a % MOD;
    }
    return ans;
}

int main()
{
    int T;
    for (int i = 1; i < MOD; i++)
    {
        res[i] = inv(i, MOD - 2);
    }

    while (~scanf("%d", &T))
    {
        scanf("%s", s + 1);
        int len = (int)strlen(s + 1);
        num[0] = p[0] = 1;
        for (int i = 1; i <= len; i++)
        {
            num[i] = num[i - 1] * (s[i] - 28) % MOD;
            p[i] = res[num[i]];
        }
        while (T--)
        {
            int x, y;
            scanf("%d %d", &x, &y);
            printf("%d\n", num[y] * p[x - 1] % MOD);
        }
    }

    return 0;
}
之前没有学过逆元,这是第二次使用到这个,今天专门花了一天时间了解了一下逆元的用处,是个牛逼的东西。
版权声明:听说这里让写版权声明~~~

百度之星2014-2016资格赛试题及解答

百度之星2014-2016资格赛试题、解答及代码实现
  • u014800380
  • u014800380
  • 2017年07月05日 11:34
  • 533

2016 百度之星 资格赛

A 没想太多,设个逆元就过了。B 斐波那契数列高精度。n == 0时输出换行。。。C 字典树,记录结点的单词数 以及 当前结点是否是单词的末尾,delete时需要先找出前缀对应的串数,统计末尾结...
  • chenzhenyu123456
  • chenzhenyu123456
  • 2016年05月14日 17:09
  • 330

2016"百度之星" - 资格赛

百度之星 2016资格赛 B题
  • leexiaobin1993
  • leexiaobin1993
  • 2016年05月15日 23:37
  • 127

2016百度之星资格赛

Problem Description 度熊面前有一个全是由1构成的字符串,被称为全1序列。你可以合并任意相邻的两个1,从而形成一个新的序列。对于给定的一个全1序列,请计算根据以上方法,可以构成多少...
  • bao_libra
  • bao_libra
  • 2016年05月14日 18:16
  • 386

2016"百度之星" - 初赛(Astar Round2A)解题报告

2016"百度之星" - 初赛(Astar Round2A)解题报告
  • queuelovestack
  • queuelovestack
  • 2016年05月21日 19:33
  • 6006

2016百度之星总结帖

2016百度之星总结帖
  • qq_32209643
  • qq_32209643
  • 2016年05月22日 19:14
  • 5163

HDU5700 2016百度之星初赛Astar Round1A 区间交

简单的数据结构题 由于所有的数都是非负整数,所以对于一个确定的左端点,区间交最大时右端点尽可能向右取; 先将所有的区间按照 左端点 从小到大 排序; 枚举区间交的左端点,那么该区间交最大时的右...
  • di4CoveRy
  • di4CoveRy
  • 2016年06月14日 13:25
  • 419

百度之星2016初赛(第二场) -- Astar Round2B

1003  签到题,其实就是输出一个取模后的组合数,需要用到乘法逆元。#include #include #include #include #include ...
  • squee_spoon
  • squee_spoon
  • 2016年05月22日 20:14
  • 450

百度之星2016资格赛 D

百度之星2016资格赛 D
  • bjydlcq
  • bjydlcq
  • 2016年05月15日 22:46
  • 269

2016百度之星资格赛C

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5687 题意: 度熊手上有一本神奇的字典,你可以在它里面做如下三个操作: 1、inse...
  • chy20142109
  • chy20142109
  • 2016年05月16日 19:43
  • 459
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:2016"百度之星"-资格赛-1001-A
举报原因:
原因补充:

(最多只允许输入30个字)