题目:

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. codeforce Gym 100685E Epic Fail of a Genie(MaximumProduction 贪心)

    题意:给出一堆元素,求一个子集,使子集的乘积最大,如有多个,应该使子集元素个数尽量小. 题解:贪心,如果有大于1的正数,那么是一定要选的,注意负数也可能凑出大于1的正数,那么将绝对值大于1的负数两两配 ...

  2. CF Gym 100637J Superfactorial numeral system (构造)

    题意:给一个式子,ak,k>2时,0<=ak<k:ai都是整数,给你p,q让你求一组ak. 题解:构造,每次除掉q取整得到ai,然后减一减 #include<cstdio> ...

  3. python之函数名的应用

    1. 函数名是一个特殊的变量 例题 例题1: a = 1 b = 2 c = a + b print(c) # 输出结果 3 # 总结 # 变量是否可以进行相加或者拼接操作是又后面指向的值来决定的,指 ...

  4. [vijos]P1514 天才的记忆

    背景 神仙飞啊飞 描述 从前有个人名叫W and N and B,他有着天才般的记忆力,他珍藏了许多许多的宝藏.在他离世之后留给后人一个难题(专门考验记忆力的啊!),如果谁能轻松回答出这个问题,便可以 ...

  5. 二叉搜索树详解(Java实现)

    1.二叉搜索树定义 二叉搜索树,是指一棵空树或者具有下列性质的二叉树: 若任意节点的左子树不空,则左子树上所有节点的值均小于它的根节点的值: 若任意节点的右子树不空,则右子树上所有节点的值均大于它的根 ...

  6. Linux基础学习-网络管理

    Linux系统网络管理NetworkManager 1 启动网络管理服务和开机自启动 在rhel7中网路管理相关命令nmcli,nmtui,nmtui-edit,nm-connection-edito ...

  7. poj-1979 red and black(搜索)

    Time limit1000 ms Memory limit30000 kB There is a rectangular room, covered with square tiles. Each ...

  8. SDUSToj第十一次作业源代码格式问题

    Problem I: 源代码的格式 Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 1471  Solved: 634 [Submit][Status][W ...

  9. POJ:1753-Flip Game(二进制+bfs)

    题目链接:http://poj.org/problem?id=1753 Flip Game Time Limit: 1000MS Memory Limit: 65536K Description Fl ...

  10. 新游发布:《Don't touch the color》

    这是笨猫工作室最后一个Scratch 2.0游戏,经过笨猫工作室成员的不懈努力,游戏终于可以稳定运行.此次更新添加了最高分数显示,优化了系统流畅度.快来试玩吧!!! 卡搭蓝链:https://kada ...