NOIP赛前模拟20171027总结
题目:
1.寿司
给定一个环形的RB串··要求经过两两互换后RB分别形成两段连续区域,求最少操作次数(算法时间O(n))
2.金字塔
给定一个金字塔的侧面图有n层··已知每一层的宽度··高度均为1··要求在图中取出恰好K个互不相交的矩形(边缘可以重叠),求最多可以取出多少面积
n<=20000,k<=100
3.心灵治愈
给定n,m要求取出不大于m的n个正整数,问有多少种取法使n个数和m的最大公因数为1,n,m<=10^15
题解:
1.分析
首先为了方便我们把环从中间断开看成一个序列,我们考虑如果移动R串··那么肯定是找到某一B为中心··B的左边R移到一起··B的右边R移到一起(这里描述有点模糊···如果序列左边的R都移到一起,且序列最左边为R,右边同理··则实际在环中R肯定是连续的一段··)
因此我们先随意找一个B为中心··然后计算答案··之后我们一次将序列最左端的字符移到最右端(比如序列BBRRR移动后就变成BRRRB)然后考虑答案的变化即可···具体实现参见代码
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<cstring>
#include<string>
#include<algorithm>
using namespace std;
const int N=2e6+;
int T,n,num[N];
char s[N];
int main()
{
//freopen("a.in","r",stdin);
//freopen("a.out","w",stdout);
scanf("%d",&T);
while(T--)
{
long long ans=,cnt=;
int tot1=,tot2=,totl=,totr=,mid;
scanf("%s",s+);n=strlen(s+);
for(int i=;i<=n;i++)
{
if(s[i]=='B') num[i]=num[i+n]=,tot1++;
else num[i]=num[i+n]=,tot2++;
}
int half=(tot1+)/;int temp=;
for(int i=;i<=n;i++)
{
if(num[i]==) {temp++;if(temp==half) mid=i;}
else
{
if(temp<half){totl++;cnt+=temp;}
else {totr++;cnt+=(tot1-temp);}
}
}
ans=cnt;
for(int i=;i<n;i++)
{
if(num[i]==)
{
int tot=,j;
for(j=mid+;num[j]!=;j++) tot++;
cnt-=totl;cnt+=(totr-tot);mid=j;
totl+=tot;totr-=tot;
if(tot1%==) cnt-=tot;
ans=min(ans,cnt);
}
else
{
totl-=;totr+=;
}
}
cout<<ans<<endl;
}
return ;
}
2.dp+决策单调性/斜率优化
dp方程肯定很好想··第一要明确取的方案··我们肯定是以某一层的宽度为矩形的一边··然后往下取到某一层为一个矩形·矩形的高就是两层高的差··
然后设f[j][i]为第j块矩形以第i层为一边的最大面积··转移方程即为:
f[j][i]=max(f[j][i],f[k][i-1]+(long long)len[j]*(j-k));
其中k为我们往下枚举的层数··len为j层的宽度··
然后通过打表(dalao也可以分析)得出该方程满足决策单调性且使用于斜率优化····这里两种方法都能过
决策单调性:
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<string>
#include<cstring>
#include<algorithm>
using namespace std;
inline int R()
{
char c;int f=;
for(c=getchar();c<''||c>'';c=getchar());
for(;c<=''&&c>='';c=getchar()) f=(f<<)+(f<<)+c-'';
return f;
}
const int N=;
const int M=;
struct node
{
int l,r,pos;
}Que[N];
int n,K;
long long len[N],f[N][M];
inline long long calc(int i,int j,int now)
{
return f[j][now-]+(long long)len[i]*(i-j);
}
inline int find(node a,int b,int now)
{
int le=a.l,ri=a.r,ans=a.r+;
while(le<=ri)
{
int mid=(le+ri)/;
if(calc(mid,b,now)>calc(mid,a.pos,now)) ri=mid-,ans=mid;
else le=mid+;
}
return ans;
}
inline void dp(int now)
{
int Head=,Tail=;
node tmp;tmp.l=now;tmp.r=n;tmp.pos=now-;Que[++Tail]=tmp;
for(int i=now;i<=n;i++)
{
while(Que[Head].r<i) Head++;
f[i][now]=calc(i,Que[Head].pos,now);
if(calc(n,i,now)>calc(n,Que[Tail].pos,now))
{
while(Head<=Tail&&calc(Que[Tail].l,i,now)>calc(Que[Tail].l,Que[Tail].pos,now)) Tail--;
if(Head<=Tail)
{
int t=find(Que[Tail],i,now);
Que[Tail].r=t-;
node tmp;tmp.l=t,tmp.r=n,tmp.pos=i;Que[++Tail]=tmp;
}
else
{
node tmp;tmp.l=i+;tmp.r=n;tmp.pos=i;Que[++Tail]=tmp;
}
}
}
}
int main()
{
//freopen("pyramid.out","w",stdout);
n=R(),K=R();int x,y;
if(n<=)
{
for(int i=;i<=n;i++)
{
x=R(),y=R();len[i]=y-x+;f[i][]=(long long)len[i]*i;
}
for(int i=;i<=K;i++)
for(int j=i;j<=n;j++)
for(int k=i-;k<j;k++) f[j][i]=max(f[j][i],f[k][i-]+(long long)len[j]*(j-k));
long long ans=;
for(int i=K;i<=n;i++) ans=max(f[i][K],ans);
cout<<ans<<"\n";
}
else
{
for(int i=;i<=n;i++)
{
x=R(),y=R();len[i]=y-x+;f[i][]=(long long)len[i]*i;
}
for(int i=;i<=K;i++)
dp(i);
long long ans=;
for(int i=K;i<=n;i++) ans=max(f[i][K],ans);
cout<<ans<<"\n";
}
return ;
}
3.质因数分解+容斥原理
这道题和之前跳蚤的那道题是一模一样的··这里就并不多说了··
唯一注意的是我发现了自己快速幂的一个漏洞··求a^b之前要将a取模···之前一直没有注意到···还有就是注意最后答案为负的问题
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<cstring>
#include<string>
#include<algorithm>
#include<vector>
using namespace std;
vector<long long>zhiyinzi;
const long long mod=1e9+;
long long n,m,ans=;
inline long long ksm(long long a,long long b)
{
long long ans=;a%=mod;
while(b)
{
if(b%==) ans=(ans*a)%mod;
b/=;a=(a*a)%mod;
}
return ans;
}
inline void dfs(int u,long long tot,long long f)
{
if(u==zhiyinzi.size())
{
long long temp=m/tot;
ans=(ans+f*ksm(temp,n))%mod;
ans=(ans%mod+mod)%mod;
return;
}
dfs(u+,tot,f);
dfs(u+,tot*zhiyinzi[u],-f);
}
int main()
{
scanf("%I64d%I64d",&n,&m);
long long temp=m;
for(long long i=;i*i<=m;i++)
{
if(i>temp) break;
if(temp%i==)
{
while(temp%i==) temp/=i;
zhiyinzi.push_back(i);
}
}
if(temp!=) zhiyinzi.push_back(temp);
dfs(,,);
ans=(ans%mod+mod)%mod;
cout<<ans<<endl;
return ;
}
NOIP赛前模拟20171027总结的更多相关文章
- NOIP 赛前模拟记录
8.11 T1 给定一个序列M,求出能过构造出的序列使得(Si+Si+1)/2=Mi成立的序列个数.保证M,S递增. T2 平面点集中最大的四边形面积 T3 不太懂得一道国家队选拔的加强版. 90+2 ...
- 刷题总结——纸带(NOIP赛前模拟)
题目: 有一个无限长的纸带··上面被划分为若干个格子··现在进行N次操作,第i次操作在L到R上擦出曾经写上的数字(如果有),并写上数字i,询问最终可以看到多少个数字 N小于10^6 题解: 首先毫无疑 ...
- NOIP赛前集训备忘录(含每日总结)(日更?。。。)
NOIP赛前集训备忘录(含每日考试总结) 标签: 有用的东西~(≧▽≦)/~啦啦啦 阅读体验:https://zybuluo.com/Junlier/note/1279194 考试每日总结(这个东西是 ...
- 牛客网NOIP赛前集训营-提高组(第四场)游记
牛客网NOIP赛前集训营-提高组(第四场)游记 动态点分治 题目大意: \(T(t\le10000)\)组询问,求\([l,r]\)中\(k(l,r,k<2^{63})\)的非负整数次幂的数的个 ...
- 2018年牛客网NOIP赛前训练营游记
2018年牛客网NOIP赛前训练营游记 提高组(第一场) 中位数 #include<cstdio> #include<cctype> #include<climits&g ...
- 牛客网NOIP赛前集训营-提高组(第四场)B区间
牛客网NOIP赛前集训营-提高组(第四场)B区间 题目描述 给出一个序列$ a_1 \dots a_n$. 定义一个区间 \([l,r]\) 是好的,当且仅当这个区间中存在一个 \(i\),使得 ...
- 牛客网NOIP赛前集训营-提高组(第四场)B题 区间
牛客网NOIP赛前集训营-提高组(第四场) 题目描述 给出一个序列 a1, ..., an. 定义一个区间 [l,r] 是好的,当且仅当这个区间中存在一个 i,使得 ai 恰好等于 al, al+1, ...
- NOIP前模拟赛总结
NOIP前模拟赛总结 from 2018.10.7 to ??? Date Name Score(Rank) Problems 2018.10.7 McfXH AK Contest 42(?) 期望得 ...
- 牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告
目录 牛客网NOIP赛前集训营-普及组(第二场) A 你好诶加币 B 最后一次 C 选择颜色 D 合法括号序列 牛客网NOIP赛前集训营-提高组(第二场) A 方差 B 分糖果 C 集合划分 牛客网N ...
随机推荐
- [opencv] applyColorMap
applyColorMap 功能 转化为热力图,因为热力图我们看的变化更加细微,在很多地方都用到了热力图. 最近在看CAM,所以记一记这个函数. 感觉还是很有用的. 代码 >>> i ...
- [视觉] 基于YoloV3的实时摄像头记牌器
基于YoloV3的实时摄像头记牌器 github:https://github.com/aoru45/cards_recognition_recorder_pytorch 最终效果 数据准备 数据获取 ...
- [web开发] Vue + spring boot + echart 微博爬虫展示平台
1.微博登录 2.爬取数据 3.mysql存储 4.pyechart本地展示 5.用vue搭建网站web展示 先放图: 1.微博登录 新浪微博的登录不是简单的post就能解决的,他的登录有加密,所以我 ...
- 阻止form元素内的input标签回车提交表单
<form></form>标签内input元素回车会默认提交表单. 阻止回车默认提交表单: $('form').on('keydown', function (event) { ...
- Dapper学习总结
看了<Dapper从入门到精通>后的总结 (1)Dapper 是直接扩展 IDBConnection,而且是单独一个文件,可以直接嵌入到项目中使用. (2)通过手写sql语句,调用exec ...
- skynet 学习笔记-netpack模块(1)
int luaopen_netpack(lua_State *L) { luaL_checkversion(L); luaL_Reg l[] = { { "pop", lpop } ...
- mongo 副本集+分片 配置
服务器规划如下: 副本集名称|服务器IP 192.168.56.111 192.168.56.112 192.168.56.113 shard1 3201 3201 3201 shard2 3202 ...
- tp5使用外部类的三种方法
在tp5中使用外部类的时候有三种方法 第一种就是通过composer下载,通过这种方式下载的外部类能够支持自动加载,我们只要在使用的时候use一下命名空间就可以使用了 比如:我们的tp5第四季项目要使 ...
- 购物车小程序(while循环,列表)
while True: salary = input("please input your salary:") if salary.isdigit(): salary=int (s ...
- 并查集:POJ1182-食物链(并查集比较高端的应用)
食物链 Time Limit: 1000MS Memory Limit: 10000K Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C ...