2018.8.10 提高B组模拟赛
T1 阶乘
Time Limits: 1000 ms Memory Limits: 262144 KB Detailed Limits
Goto ProblemSet
Description
有n个正整数a[i],设它们乘积为p,你可以给p乘上一个正整数q,使p*q刚好为正整数m的阶乘,求m的最小值。
Input
共两行。
第一行一个正整数n。
第二行n个正整数a[i]。
Output
共一行
一个正整数m。
Sample Input
1
6
Sample Output
3
样例解释:
当p=6,q=1时,p*q=3!
Data Constraint
对于10%的数据,n<=10
对于30%的数据,n<=1000
对于100%的数据,n<=100000,a[i]<=100000
解题思路
可以发现被选出的m的阶乘的每个质因数的个数都一定大于a[i]的乘积,所以可以二分答案,然后判断。
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
const int MAXN = 100005;
typedef long long LL;
inline int rd(){
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-1;ch=getchar();}
while(isdigit(ch)) {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return x*f;
}
int n,cnt,prime[10000],ans,mx;
LL num[MAXN];
bool vis[MAXN];
inline void solve(int x){
int t=0;
while(++t){
while(x%prime[t]==0){
num[prime[t]]++;
x/=prime[t];mx=max(mx,t);
}
if(x==1) break;
}
}
inline bool check(int x){
for(register int i=1;i<=mx;i++){
int now=0;
for(register int j=prime[i];j<=x;j=j*prime[i]) {
now+=x/j;
if(now>=num[prime[i]]) break;
}
if(now<num[prime[i]]) return false;
}return true;
}
int main(){
freopen("factorial.in","r",stdin);
freopen("factorial.out","w",stdout);
for(register int i=2;i<=100000;i++){
if(!vis[i]) {prime[++cnt]=i;vis[i]=1;}
for(register int j=1;j<=cnt && (LL)prime[j]*i<=100000;j++) {
vis[i*prime[j]]=1;
if(i%prime[j]==0) break;
}
}
n=rd();
for(register int i=1;i<=n;i++){
int x=rd();
solve(x);
}
int l=1,r=1e9;
while(l<=r){
int mid=l+r>>1;
if(check(mid)){
ans=mid;
r=mid-1;
}else l=mid+1;
}cout<<ans<<endl;
return 0;
}
T2 小S爱跑步
Description
小S是一个爱锻炼的孩子,他在放假期间坚持在A公园练习跑步。
但不久后,他就开始为在重复的地点练习感到厌烦了,他就打算去B公园跑步。
但是小S由于没有去过B公园,他不知道B公园是否适合练习跑步,又不知道在B公园怎样跑是最优的。所以小S就去B公园进行了一番勘测。
小S在进行了一番勘测后,画出了一张地图,地图每一个位置上都辨识了小S到达该位置后不能往哪一个方位移动。其中有5种表示的符号:“U”代表不能向上移动,“D”代表不能向下移动,“L”代表不能向左移动,“R”代表不能向右移动,如果该位置有障碍物,小S到达那里后无法继续训练,就用“S”来代表。整个公园共有n行m列,小S会从第1行第1列出发,到第n行第m列结束他的练习。
现在小S想要知道,从起点(即第1行第1列)到终点(第n行第m列),途中最少要改变几次方向(即上一次移动的方向和这一次移动的方向不一样)?
注意:小S如在训练途中离开公园(即地图范围),则算是结束训练。
Input
第1行两个整数n和m,它们的定义请看【题目描述】。
第2~n+1行,每行有m个字符,表示小S的移动方向。
Output
如果小S从第1行第1列出发无论如何都到达不了第n行第m列,输出“No Solution”,否则输出小S途中最少要改变方向的次数。
Sample Input
3 3
ULL
LDU
SUD
Sample Output
1
【样例解释】
小S先向右移动移动了2格,再向下移动2格,就到达了终点,这样只用改变一次方向。
Data Constraint
【数据范围限制】
10%的数据是题目的馈赠。
30%的数据,1≤n,m≤10。
50%的数据,1≤n,m≤50。
70%的数据,1≤n,m≤250。
100%的数据,1≤n,m≤500.
其中50%的数据是先构造出路径,再构造地图的。
100%数据是随机构造的。
解题思路
直接bfs,模仿spfa的形式。
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int MAXN = 505;
int n,m,ans[MAXN][MAXN][8];
int xx[5]={0,0,0,1,-1},yy[5]={0,-1,1,0,0};
char c[MAXN][MAXN];
bool vis[MAXN][MAXN][8];
queue<int> Q[4];
inline int pre(char ch){
if(ch=='S') return 0;
if(ch=='L') return 1;
if(ch=='R') return 2;
if(ch=='D') return 3;
return 4;
}
int main(){
freopen("run.in","r",stdin);
freopen("run.out","w",stdout);
memset(ans,0x3f,sizeof(ans));
scanf("%d%d",&n,&m);
for(register int i=1;i<=n;i++) scanf("%s",c[i]+1);
Q[1].push(1);Q[2].push(1);Q[3].push(5);vis[1][1][5]=1;ans[1][1][5]=-1;
while(Q[1].size()){
int x=Q[1].front(),y=Q[2].front(),k=Q[3].front();int w=ans[x][y][k];
Q[1].pop();Q[2].pop();Q[3].pop();if(c[x][y]=='S') continue;
for(register int z=1;z<=4;z++){
if(pre(c[x][y])==z) continue;
int ii=xx[z]+x;int jj=yy[z]+y;
if(ii>=1 && ii<=n && jj>=1 && jj<=m)
if(ans[ii][jj][z]>w+(z!=k)){
ans[ii][jj][z]=w+(z!=k);
if(!vis[ii][jj][z]){
Q[1].push(ii);Q[2].push(jj);Q[3].push(z);
vis[ii][jj][z]=1;
}
}
}
vis[x][y][k]=0;
}ans[n][m][1]=min(ans[n][m][1],ans[n][m][0]);
cout<<min(min(min(ans[n][m][1],ans[n][m][2]),ans[n][m][3]),ans[n][m][4]);
return 0;
}
2018.8.10 提高B组模拟赛的更多相关文章
- 2018 8.8 提高A组模拟赛
T1 Description 被污染的灰灰草原上有羊和狼.有N只动物围成一圈,每只动物是羊或狼. 该游戏从其中的一只动物开始,报出[1,K]区间的整数,若上一只动物报出的数是x,下一只动物可以报[x+ ...
- JZOJ5804. 【2018.08.12提高A组模拟】简单的序列
性质:每个位置的前缀和必须大于0,总和=0.以此dp即可. #include <iostream> #include <cstdio> #include <cstring ...
- NOIP2017提高组模拟赛 10 (总结)
NOIP2017提高组模拟赛 10 (总结) 第一题 机密信息 FJ有个很奇怪的习惯,他把他所有的机密信息都存放在一个叫机密盘的磁盘分区里,然而这个机密盘中却没有一个文件,那他是怎么存放信息呢?聪明的 ...
- JZOJ 5818. 【NOIP提高A组模拟2018.8.15】 做运动
5818. [NOIP提高A组模拟2018.8.15] 做运动 (File IO): input:running.in output:running.out Time Limits: 2000 ms ...
- JZOJ 5812. 【NOIP提高A组模拟2018.8.14】 区间
5812. [NOIP提高A组模拟2018.8.14] 区间 (File IO): input:range.in output:range.out Time Limits: 1000 ms Memo ...
- ZROI提高组模拟赛05总结
ZROI提高组模拟赛05总结 感觉是目前为止最简单的模拟赛了吧 但是依旧不尽人意... T1 有一半的人在30min前就A掉了 而我花了1h11min 就是一个简单的背包,我硬是转化了模型想了好久,生 ...
- NOIP2017提高组 模拟赛15(总结)
NOIP2017提高组 模拟赛15(总结) 第一题 讨厌整除的小明 [题目描述] 小明作为一个数学迷,总会出于数字的一些性质喜欢上某个数字,然而当他喜欢数字k的时候,却十分讨厌那些能够整除k而比k小的 ...
- NOIP2017提高组 模拟赛13(总结)
NOIP2017提高组 模拟赛13(总结) 第一题 函数 [题目描述] [输入格式] 三个整数. 1≤t<10^9+7,2≤l≤r≤5*10^6 [输出格式] 一个整数. [输出样例] 2 2 ...
- NOIP2017提高组模拟赛 9 (总结)
NOIP2017提高组模拟赛 9 (总结) 第一题 星星 天空中有N(1≤N≤400)颗星,每颗星有一个唯一的坐标(x,y),(1≤x,y ≤N).请计算可以覆盖至少K(1≤K≤N)颗星的矩形的最小面 ...
随机推荐
- 如何学习AxureRP Axure学习方法
从作者最初接触的5.5版本,到5.6版本,到后来6.0的多个迭代版本,直到现在的6.5版本,AxureRP每次的版本升级都伴随着新功能的增 加,也解决了原型设计上的一些难题.这也从另一个方面诠释了“学 ...
- <每日一题>题目19:简单的程序执行效率面试题
# 将下面的函数按照执行效率高低排序.它们都接受由0至1之间的数字构成的列表作为输入.这个列表可以很长.一个输入列表的示例如下:[random.random() for i in range(1000 ...
- 怎么解决VirtualBox无法安装增强工具
点击「设备」-「安装增强功能」,然后就弹出下面这个东西,百度和 bing 了很久,终于解决啦~ Unable to insert the virtual optical disk D:\Program ...
- 编译安装Python3.6.1
系统:CentOS 7 Python: 3.6.1 去官方网站下载Python的源码包 然后准备开发环境和服务器平台开发 注意:python编译还依赖一个zlib-devel(本人第一次编译就因为不知 ...
- [转]Visual Studio 2010生成解决方案时,提示磁盘空间不足!
最近几天,使用VS调试时总是出现提示:磁盘空间不足.我觉得可能有两种可能: 1.系统盘已被木马侵袭.历时4小时的全盘扫描没有病毒提示,只好删除了一些不必要的软件: 2.使用VS2010调试 ...
- Ionic 左侧菜单(登录主页详情demo)
1.项目结构 2.截图效果展示 3.主要js 代码 $stateProvider .state('app', { url: "/app", abstract: tru ...
- Django项目:CRM(客户关系管理系统)--60--50PerfectCRM实现CRM客户报名流程学生合同URL随机码
# sales_urls.py # ————————47PerfectCRM实现CRM客户报名流程———————— from django.conf.urls import url from bpm. ...
- light oj 1068 数位dp
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <math.h> ...
- 工控安全入门(五)—— plc逆向初探
之前我们学习了包括modbus.S7comm.DNP3等等工控领域的常用协议,从这篇开始,我们一步步开始,学习如何逆向真实的plc固件. 用到的固件为https://github.com/ameng9 ...
- gin框架中间件
1. Gin框架中间件Gin框架中间件A. Gin框架允许在请求处理过程中,加入用户自己的钩子函数.这个钩子函数就叫中间件B. 因此,可以使用中间件处理一些公共业务逻辑,比如耗时统计,日志打印,登陆校 ...