传送门:

  [1]:UPC比赛场

  [2]:UPC补题场

F.gu集合(数论)

•题目描述

 题目描述:
Dew有一个长为n的集合S。
有一天,他想选k个不同的元素出来做游戏。
但是Dew只有两只手,所以他只能先选出k个元素,然后拿出这k个元素中最小的两个。
事实上,Dew更喜欢这k个元素中第二小的那个。
因此他会记一个集合T的第二小值为g(T)。
此时Dew可以获得c^g(T)!的得分,其中c是一个常数,!表示阶乘。
现在你需要求出Dew从集合S中选出k个元素后,他的期望得分对998244353取模的结果。 输入:
输入共两行。
第一行三个正整数n,k,c,分别表示集合S的大小,Dew要选的元素个数,和常数c。
第二行n个互不相同的正整数ai,表示集合S中的元素。保证集合s升序。 输出:
输出一行一个非负整数,表示Dew的期望得分对998244353取模的结果。

题目描述、输入、输出

 样例输入

 样例输出
 

样例输入输出

样例解释

•题解

  在tyk的帮助下顺利AC;

  下面开始扯淡;

  第 i 个数 ai 可以作为第二小的数的条件是:

    ①存在比 ai 小的数,即 i > 1;

    ②比 ai 大的数的个数要多于 k-2,即 n-i ≥ k-2;

  对于满足条件的 ai,共有

  

  那么得到 ai 的概率为:

  

  最终答案就是 ∑ Pi×cai!

•细节处理

  对于除法取模Pi%MOD直接用逆元处理即可,关键是 cai该如何处理?

  根据费马小定理:ap-1 ≡ 1 (mod p) 可知循环节为 p-1(ap-1 ≡ a0 (mod p) ⇔ 0~p-2 为一个循环) ;

  即 ax ≡ ax%(p-1) (mod p) ;

  那么 cai≡ cai!%(p-1)(mod p);

  而 ai!%(p-1) 可以提前预处理出来;

•Code

 #include<bits/stdc++.h>
using namespace std;
#define ll long long
const int MOD=;
const int maxn=5e5+; int n,k,c;
int a[maxn];
ll fact[maxn];///fact只开到5e5就足够了,如果开到1e7,返回内存超限
ll g[(int)1e7+]; ll qPow(ll a,ll b)
{
ll ans=;
a %= MOD;
while(b)
{
if(b&)
ans=ans*a%MOD; a=a*a%MOD;
b >>= ;
}
return ans;
}
int Solve()
{
fact[]=g[]=;
for(int i=;i < maxn;++i)
fact[i]=i*fact[i-]%MOD;
for(int i=;i <= (int)1e7;++i)
g[i]=i*g[i-]%(MOD-); ll ans=;
for(int i=;i <= n;++i)
{
if(n-i < k-)
break; ll b=fact[k-]*fact[n-i-k+]%MOD*fact[n]%MOD;///概率的分母取模后的结果
///qPow(b,MOD-2)为逆元
ll p=(i-)*fact[n-i]%MOD*fact[k]%MOD*fact[n-k]%MOD*qPow(b,MOD-)%MOD; ans += p*qPow(c,g[a[i]]);
ans %= MOD;
}
return ans;
}
int main()
{
scanf("%d%d%d",&n,&k,&c);
for(int i=;i <= n;++i)
scanf("%d",a+i); printf("%d\n",Solve()); return ;
}

•感悟

  满满的数论知识,有些知识点早就学过,但就学死了,没能做到活用;

  看来,还是得多做题,多总结,要活学活用;


H.奇迹(暴力+欧拉筛法)

•题目描述

题目描述
相信奇迹的人,本身就和奇迹一样了不起。——笛亚 《星游记》
我们称一个日期为一个八位数,第1~4位构成年,第5~6位构成月,第7~8位构成日,不足位数用0补足。
同时,要求日期所代表的这一天真实存在,且年的范围为1~。
出现奇迹的日期都存在相同的特点:由“日”组成的两位数,由“月+日”组成的四位数,由“年+月+日”组成的八位数均为质数。
但并不是所有存在这样特点的日期都一定会出现奇迹。
现在,你得到了一个可能会出现奇迹的日期,然而不幸的是这个日期却是残缺的,八位中可能有若干位无法确定。
你需要知道这个日期有多少种可能,这样你才能做好充足的准备去迎接奇迹的到来。 输入
本题有多组数据。
第一行一个正整数T,表示数据组数。
接下来的T行,每行一个八位字符串。
其中第i位如果为 '-',则表示日期的第i位无法确定,否则表示日期的第i位为字符串中第i位上的数字。 输出
对每组数据,一行一个整数,表示答案。

题目描述、输入、输出

样例输入

---

样例输出

样例输入输出

--- 的  种可能的日期如下:

一共10个测试点,记c为八位字符串中 '-' 的个数。
对前9个测试点,在第i个测试点中保证c=i-。
对100%的数据保证1≤T≤。

提示

•题解(暴力+欧拉筛法预处理)

  枚举所有可能的日期,并判断①其是否符合字符串 s;②符合正常日期;

  在满足上述条件的请款下,并判断其是否符合出现奇迹的要求,如果符合,ans++;

•Code

 #include<bits/stdc++.h>
using namespace std;
#define mem(a,b) memset(a,b,sizeof(a))
const int day[][]={{,,,,,,,,,,,,},
{,,,,,,,,,,,,}/**闰年*/};
char s[]; int prime[];
bool isPrime[];
void Prime()
{
mem(isPrime,true);
int cnt=;
isPrime[]=false;
for(int i=;i < ;++i)
{
if(isPrime[i])
prime[++cnt]=i;
for(int j=;j <= cnt && prime[j]*i < ;++j)
{
isPrime[i*prime[j]]=false;
if(i%prime[j] == )
break;
}
}
}
bool isRun(int y)
{
return (y% != && y% == )||(y% == );
}
bool isSatY(int y)
{
if(s[] != '-' && (s[]-'') != y/)
return false;
if(s[] != '-' && (s[]-'') != y/%)
return false;
if(s[] != '-' && (s[]-'') != y/%)
return false;
if(s[] != '-' && (s[]-'') != y%)
return false; return true;
}
bool isSatM(int m)
{
if(s[] != '-' && (s[]-'') != m/)
return false;
if(s[] != '-' && (s[]-'') != m%)
return false; return true;
}
bool isSatD(int d)
{
if(s[] != '-' && (s[]-'') != d/)
return false;
if(s[] != '-' && (s[]-'') != d%)
return false; return true;
}
int Solve()
{
int ans=;
for(int y=;y <= ;y++)
{
if(!isSatY(y))///判断y是否符合s
continue; for(int m=;m <= ;m++)
{
if(!isSatM(m))///判断m是否符合s
continue; for(int d=;d <= day[isRun(y)][m];d++)///判断m是否符合s
if(isSatD(d) && isPrime[m*+d] && isPrime[d] && isPrime[y*+m*+d])
ans++;
}
}
return ans;
}
int main()
{
Prime();///预处理1~99991232内的所有素数 int T;
scanf("%d",&T);
while(T--)
{
scanf("%s",s+);
printf("%d\n",Solve());
}
return ;
}

思考

上述代码耗时:

如果将三重循环的顺序颠倒以下,改成如下顺序:

 int Solve()
{
int ans=;
for(int d=;d <= ;++d)
{
if(!isPrime[d] || !isSatD(d))
continue;
for(int m=;m <= ;++m)
{
if(!isPrime[d+m*] || !isSatM(m))
continue;
for(int y=;y <= ;++y)
{
if(!isPrime[y*+m*+d] || d > day[isRun(y)][m] || !isSatY(y))
continue;
ans++;
}
}
}
return ans;
}

耗时:

快了将近三百毫秒!!!

对于此题而言,颠倒一下顺序,枚举的情况会少一下;

•坑

起初,我用vector<>存储的prime,返回 TLE,改成 int 后,AC;

看来,动态分配空间还是比提前计算出所需的空间慢一些;

UPC 2019年第二阶段我要变强个人训练赛第十六场的更多相关文章

  1. UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十六场

    E: 飞碟解除器 •题目描述 wjyyy在玩跑跑卡丁车的时候,获得了一个飞碟解除器,这样他就可以免受飞碟的减速干扰了.飞碟解除器每秒末都会攻击一次飞碟,但每次只有p/q的概率成功攻击飞碟.当飞碟被成功 ...

  2. UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十四场

    A.JOIOJI •传送门 [1]:BZOJ [2]:洛谷 •思路 在一个区间(L,R]内,JOI的个数是相等的,也就是R[J]-L[J]=R[O]-L[O]=R[I]-L[I], 利用前缀和的思想, ...

  3. UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十五场

    传送门 A: Colorful Subsequence •题意 给一个长为n的小写字母序列,从中选出字母组成子序列 问最多能组成多少种每个字母都不相同的子序列 (不同位置的相同字母也算是不同的一种) ...

  4. UPC 2019年第二阶段我要变强个人训练赛第六场

    传送门 A.上学路线 题目描述 小D从家到学校的道路结构是这样的:由n条东西走向和m条南北走向的道路构成了一个n*m的网格,每条道路都是单向通行的(只能从北向南,从西向东走). 已知小D的家在网格的左 ...

  5. 2019年第二阶段我要变强个人训练赛第八场 B.序列(seq)

    传送门 B.序列(seq) •题目描述 给出一个长度为n的序列a,每次对序列进行一下的某一个操作. •输入 第一行两个整数n,q表示序列长度和操作个数. 接下来一行n个数,表示序列a. 接下来q行表示 ...

  6. 备战省赛组队训练赛第十六场(UPC)

    传送门 题解: by 烟台大学 (提取码:8972)

  7. UPC个人训练赛第十五场(AtCoder Grand Contest 031)

    传送门: [1]:AtCoder [2]:UPC比赛场 [3]:UPC补题场 参考资料 [1]:https://www.cnblogs.com/QLU-ACM/p/11191644.html B.Re ...

  8. 备战省赛组队训练赛第十四场(UPC)

    codeforces:传送门 upc:传送门 外来题解: [1]:https://blog.csdn.net/ccsu_cat/article/details/86707446 [2]:https:/ ...

  9. 备战省赛组队训练赛第十八场(UPC)

    传送门 题解:by 青岛大学 A:https://blog.csdn.net/birdmanqin/article/details/89789424 B:https://blog.csdn.net/b ...

随机推荐

  1. Eclipse Jobs 和后台进程

    Eclipse后台进程 1.主线程(Main thread) 一个Eclipse客户端只能跑一个进程,但却可以创建很多线程. 在Eclipse框架中,会用一个单线程去运行所有的代码指令,这个线程执行客 ...

  2. django查看数据库

    #views import pymysql def get_date(request): conn = pymysql.connect( host='localhost', port=3306, us ...

  3. 利用阿里大于实现发送短信(JAVA版)

    本文是我自己的亲身实践得来,喜欢的朋 友别忘了点个赞哦! 最近整理了一下利用阿里大于短信平台来实现发送短信功能. 闲话不多说,直接开始吧. 首先,要明白利用大于发送短信这件事是由两部分组成: 一.在阿 ...

  4. metro扁平UI网页组件

    在线演示 本地下载

  5. @codeforces - 1276F@ Asterisk Substrings

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一个包含 n 个小写字母的字符串 s,用 s 生成 n 个串 ...

  6. C++之ARX,Acstring,ACahr转char

    AcDbText* pText = AcDbText::cast(pEnt); AcString sText = DBHelper::AcStringFree(pText->textString ...

  7. Quick BI独创千人千面的行级权限管控机制

    摘要 就数据访问权限而言,阿里巴巴以“被动式授权”为主,你需要什么权限就申请什么权限.但是,在客户交流过程中,我们发现绝大多数企业都是集中式授权,尤其是面向个人的行级权限管控,管理复杂度往往呈几何增长 ...

  8. 2018-7-5-dotnet-设计规范-·-抽象定义

    title author date CreateTime categories dotnet 设计规范 · 抽象定义 lindexi 2018-07-05 15:48:20 +0800 2018-2- ...

  9. vue事件获取事件对象,vue获取事件源,vue event.currentTarget

    js的事件,如点击事件,可以直接用this获取事件对象,而jQuery可以使用$(this)来获取事件对象.vue必须借助事件的 event 对象 的 currentTarget 才能获取事件对象 v ...

  10. SDUT-2122_数据结构实验之链表七:单链表中重复元素的删除

    数据结构实验之链表七:单链表中重复元素的删除 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 按照数据输入的相反顺序(逆 ...