1001  Another Meaning

题意:字符串A中包含的字符串B可以翻译或不翻译,总共有多少方案。

题解:动规,dp[i]表示A的第i位为止有多少方案。

转移方程:

dp[i]=dp[i-1](不翻译)

dp[i]+=dp[i-B.size()](翻译i结尾的子串B)

初始条件:dp[0]=1(代表不翻译的这种情况)

dp[B.size()]=2(若从A起点开始的子串是B,则有翻译和不翻译两种)

//http://acm.hdu.edu.cn/showproblem.php?pid=5763
#include<iostream>
#include<string>
using namespace std;
#define M 1000000007
#define N 100005
int t,dp[N];
string A,B;
int main(){
cin>>t;
for(int c=;c<=t;c++){
cin>>A>>B;
for(int i=;i<A.size();i++){
dp[i]=i?dp[i-]:;
if(i+>=B.size()&&A.substr(i-B.size()+,B.size())==B){
dp[i]=(dp[i]+dp[i-B.size()])%M;
if(i+==B.size())dp[i]=;
}
}
cout<<"Case #"<<c<<": "<<dp[A.size()-]<<endl;
}
return ;
}

1005  Lucky7

题意:x到y有多少个7的倍数,且满足≠ai mod pi。

题解:利用容斥定理奇加偶减,处理限制条件。

中国剩余定理求出满足ai=X%pi的最小正整数X。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
typedef long long ll;
ll p[],a[];
ll p1[],a1[],num;
ll n,x,y;
ll ans;
ll exgcd(ll l,ll r,ll &x,ll &y)
{
if(r==){x=;y=;return l;}
else
{
ll d=exgcd(r,l%r,y,x);
y-=l/r*x;
return d;
}
}
ll qmul(ll a,ll b,ll m){//快速乘法
ll ans=;
ll k=a;
while(b){
if(b&)
ans=(ans+k)%m;
k=(k+k)%m;
b>>=;
}
return ans;
}
ll Remain(ll p[],ll a[],ll m){
ll ans=;
for(int i=;i<=num;i++)
{
ll x,y,Mk=m/p[i];
exgcd(Mk,p[i],x,y);
x=(x%p[i]+p[i])%p[i];
ans=(ans+qmul(qmul(Mk,x,m),a[i],m))%m;//ans+=Mk*x*a[i]
}
return (ans+m)%m;
}
ll work()
{
ll m=;
for(int i=;i<=num;i++)
m*=(ll)p1[i];
ll sum=Remain(p1,a1,m);
ll k1=(x-sum)/m;
if(k1*m+sum<x)k1++;
if(k1<)k1=;
if(y<sum)return ;
ll k2=(y-sum)/m;
return k2-k1+;
}
void solve()
{
ans=;
for(ll i=;i<=(<<n)-;i++)
{
num=;
memset(p1,,sizeof(p1));
memset(a1,,sizeof(a1));
for(int j=;j<n;j++)
if((i&(<<j)))
{
p1[++num]=p[j+];
a1[num]=a[j+];
}
p1[++num]=;a1[num]=;
if(num%==)ans+=work();
else ans-=work();
}
return;
}
int main()
{
int t;
cin>>t;
for(int l=;l<=t;l++)
{
cin>>n>>x>>y;
for(int i=;i<=n;i++)cin>>p[i]>>a[i];
solve();
cout<<"Case #"<<l<<": "<<ans<<endl;
}
return ;
}

1012 Bubble Sort

树状数组维护数字i前面有多少个比它小的数,即第几小。最左距离就是rank,最右距离就是max(原位置,终位置),求出距离极差即可。

#include<iostream>
#include<cstdio>
#include<cstring>
#define N 100005
using namespace std;
int t,n,p[N],sum[N],ans[N];
inline int lowbit(int x){return x&(-x);}
int getsum(int x){
int s=;
for(;x;x-=lowbit(x))s+=sum[x];
return s;
}
void update(int v,int x){
for(;x<=n;x+=lowbit(x))sum[x]+=v;
}
int main(){
cin>>t;
for(int c=;c<=t;c++){
memset(sum,,sizeof sum);
cout<<"Case #"<<c<<":";
cin>>n;
for(int i=;i<=n;i++)
{
cin>>p[i];
update(,p[i]);
int r=getsum(p[i]);
ans[p[i]]=max(i-r,p[i]-r);
}
for(int i=;i<=n;i++)
cout<<" "<<ans[i];
cout<<endl;
}
return ;
}

  

 

【2016多校训练4】Multi-University Training Contest 4的更多相关文章

  1. 2016多校训练3_1007(hdu5758 Explorer Bo)

    #include <functional> #include <algorithm> #include <iostream> #include <iterat ...

  2. ACM多校联赛7 2018 Multi-University Training Contest 7 1009 Tree

    [题意概述] 给一棵以1为根的树,树上的每个节点有一个ai值,代表它可以传送到自己的ai倍祖先,如果不存在则传送出这棵树.现在询问某个节点传送出这棵树需要多少步. [题解] 其实是把“弹飞绵羊”那道题 ...

  3. 2016 Multi-University Training Contest 1

    8/11 2016 Multi-University Training Contest 1 官方题解 老年选手历险记 最小生成树+线性期望 A Abandoned country(BH) 题意: 1. ...

  4. 2016 Al-Baath University Training Camp Contest-1

    2016 Al-Baath University Training Camp Contest-1 A题:http://codeforces.com/gym/101028/problem/A 题意:比赛 ...

  5. 2015多校联合训练赛 hdu 5308 I Wanna Become A 24-Point Master 2015 Multi-University Training Contest 2 构造题

    I Wanna Become A 24-Point Master Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 ...

  6. 2015多校联合训练赛hdu 5301 Buildings 2015 Multi-University Training Contest 2 简单题

    Buildings Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Tota ...

  7. 2016 Multi-University Training Contest 3

    5/11 2016 Multi-University Training Contest 3官方题解 2016年多校训练第三场 老年选手历险记 暴力 A Sqrt Bo(CYD) 题意:问进行多少次开根 ...

  8. 2016 Multi-University Training Contest 2 D. Differencia

    Differencia Time Limit: 10000/10000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tot ...

  9. 2016 Multi-University Training Contest 1 G. Rigid Frameworks

    Rigid Frameworks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

随机推荐

  1. [No00000A]计算机的存储单位

    位 bit (比特)(Binary Digits):存放一位二进制数,即 0 或 1,最小的存储单位. 字节 byte:8个二进制[bit (比特)(Binary Digits)]位为一个字节(B), ...

  2. APIO2013 tasksauthor

    喜闻乐见的提答题,这道题还是蛮有趣的 数据结构题写得心塞,来一道提答意思意思 如果喜欢这类题的话还可以去做做uoj83. 这题是给出了两个问题,一个最短路,一个无向图染色问题. Data 1 Floy ...

  3. JavaScript继承与原型链

    对于那些熟悉基于类的面向对象语言(Java 或者 C++)的开发者来说,JavaScript 的语法是比较怪异的,这是由于 JavaScript 是一门动态语言,而且它没有类的概念( ES6 新增了c ...

  4. DocOptimizer 0.9.0 Beta Released

    DocOptimizer 是一个文档优化工具,它通过移除Excel中多余的单元格:将嵌入的OLE替换成图片:移除文档中的隐藏信息:优化文档中的图片等等手段,将Office或PDF文件压缩20%-90% ...

  5. python 测试驱动开发的简单例子

    一.需求分析 需求:一个类 MyClass,有两个功能:add, sub 1.先功能设计 # myclass.py class MyClass(object): # 加法 def add(self): ...

  6. ASP.MVC EASY UI 入门之 —— Tree & ComboTree

    1.常规的EASY UI的tree和comboTree代码基本是官方的DEMO都有的,虽然很简单,但是还是要实践的做一次,才能更清晰的了解和使用它!先上效果图 因为用的是code first,所以数据 ...

  7. 高性能JavaScript 重排与重绘

    先回顾下前文高性能JavaScript DOM编程,主要提了两点优化,一是尽量减少DOM的访问,而把运算放在ECMAScript这一端,二是尽量缓存局部变量,比如length等等,最后介绍了两个新的A ...

  8. Mininet在创建拓扑的过程中为什么不打印信息了——了解Mininet的log系统

    前言 写这篇博客是为了给我的愚蠢和浪费的6个小时买单! 过程原因分析 我用Mininet创建过不少拓扑了,这次创建的拓扑非常简单,如下图,创建拓扑的代码见github.在以前的拓扑创建过程中,我都是用 ...

  9. ffmpeg在shell循环中只执行一次问题

    最近写了一个shell脚本,发现 ffmpeg 命令只执行了一次就停了,最后找到原因: ffmpeg有时会读取标准输入流,导致命令出错,解决办法是在ffmpeg命令之后添加 #xxx ffmpeg x ...

  10. Jquery和JS获取ul中li标签(转)

    js 获取元素下面所有的li var content=document.getElementById("content"); var items=content.getElemen ...