题目:

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总结的更多相关文章

  1. NOIP 赛前模拟记录

    8.11 T1 给定一个序列M,求出能过构造出的序列使得(Si+Si+1)/2=Mi成立的序列个数.保证M,S递增. T2 平面点集中最大的四边形面积 T3 不太懂得一道国家队选拔的加强版. 90+2 ...

  2. 刷题总结——纸带(NOIP赛前模拟)

    题目: 有一个无限长的纸带··上面被划分为若干个格子··现在进行N次操作,第i次操作在L到R上擦出曾经写上的数字(如果有),并写上数字i,询问最终可以看到多少个数字 N小于10^6 题解: 首先毫无疑 ...

  3. NOIP赛前集训备忘录(含每日总结)(日更?。。。)

    NOIP赛前集训备忘录(含每日考试总结) 标签: 有用的东西~(≧▽≦)/~啦啦啦 阅读体验:https://zybuluo.com/Junlier/note/1279194 考试每日总结(这个东西是 ...

  4. 牛客网NOIP赛前集训营-提高组(第四场)游记

    牛客网NOIP赛前集训营-提高组(第四场)游记 动态点分治 题目大意: \(T(t\le10000)\)组询问,求\([l,r]\)中\(k(l,r,k<2^{63})\)的非负整数次幂的数的个 ...

  5. 2018年牛客网NOIP赛前训练营游记

    2018年牛客网NOIP赛前训练营游记 提高组(第一场) 中位数 #include<cstdio> #include<cctype> #include<climits&g ...

  6. 牛客网NOIP赛前集训营-提高组(第四场)B区间

    牛客网NOIP赛前集训营-提高组(第四场)B区间 题目描述 给出一个序列$ a_1  \dots   a_n$. 定义一个区间 \([l,r]\) 是好的,当且仅当这个区间中存在一个 \(i\),使得 ...

  7. 牛客网NOIP赛前集训营-提高组(第四场)B题 区间

    牛客网NOIP赛前集训营-提高组(第四场) 题目描述 给出一个序列 a1, ..., an. 定义一个区间 [l,r] 是好的,当且仅当这个区间中存在一个 i,使得 ai 恰好等于 al, al+1, ...

  8. NOIP前模拟赛总结

    NOIP前模拟赛总结 from 2018.10.7 to ??? Date Name Score(Rank) Problems 2018.10.7 McfXH AK Contest 42(?) 期望得 ...

  9. 牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告

    目录 牛客网NOIP赛前集训营-普及组(第二场) A 你好诶加币 B 最后一次 C 选择颜色 D 合法括号序列 牛客网NOIP赛前集训营-提高组(第二场) A 方差 B 分糖果 C 集合划分 牛客网N ...

随机推荐

  1. 2018.3.12 Leecode习题 给定一个整数数列,找出其中和为特定值的那两个数。

    给定一个整数数列,找出其中和为特定值的那两个数. 你可以假设每个输入都只会有一种答案,同样的元素不能被重用. 示例: 给定 nums = [2, 7, 11, 15], target = 9; 因为 ...

  2. db2的定时备份

    定时任务: db2.bat db2cmd -i -w db2_backup.bat exit db2_backup.bat db2 connect to TEST db2 force applicat ...

  3. 关于SpringMVC注解

    1.@RequestMapping RequestMapping是一个用来处理请求地址映射的注解(将请求映射到对应的控制器方法中),可用于类或方法上.用于类上,表示类中的所有响应请求的方法都是以该地址 ...

  4. java基础——Map集合

    Map以键值对的形式存储数据,其中Map.entry,是Map的内部类,它用来描述Map中的键值对.Map是一个接口,HashMap是他的一个实现类 Map中有几个重要的方法: get(Object ...

  5. Spring学习笔记之Spring概述

    概述   Spring是一个java应用最广的开源框架,它是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One J2EE Deve ...

  6. 实现HTTP文件下载

    [原文:http://www.jb51.net/article/89958.htm] HTTP实现文件下载时,只要在服务器设置好相关响应头,并使用二进制传输文件数据即可,而客户端(浏览器)会根据响应头 ...

  7. cocos2dx lua 打印和保存日志

    在2d游戏中,经常会出现闪退或者报错的问题,通过写文本,将日志文件发送给服务端,让后端人员进行分析. 通过lua打印日志在文本文件中: local file = io.open(cc.FileUtil ...

  8. 【思维题 单调栈】loj#2430. 「POI2014」沙拉餐厅 Salad Bar

    t老师的做法好神…… 题目描述 桌面上有 n 个水果,分别是苹果和橘子.Bytea需要从水果中选择连续的一个区间,并从左到右或从右到左拿水果,且过程中橘子的数量必须始终不小于苹果的数量.求最长的区间大 ...

  9. 【NOIP2017提高组模拟7.3】B

    树上路径统计,点分治解决. 统计一段区间,naive地用了set解决,这样的复杂度是O(nlog^2n)的 考场代码出了个问题,统计答案时找到了之前的最优答案,但是没有加上新的一段,导致60分 #in ...

  10. 洛谷 2387/BZOJ 3669 魔法森林

    3669: [Noi2014]魔法森林 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 3765  Solved: 2402[Submit][Statu ...