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. [No000040]取得一个文本文件的编码方式

    using System; using System.IO; using System.Text; /// <summary> /// 用于取得一个文本文件的编码方式(Encoding). ...

  2. Zygote进程【1】——Zygote的诞生

    在Android中存在着C和Java两个完全不同的世界,前者直接建立在Linux的基础上,后者直接建立在JVM的基础上.zygote的中文名字为"受精卵",这个名字很好的诠释了zy ...

  3. HTML 学习笔记 CSS(轮廓)

    轮廓(outline)是绘制于元素周围的一条线 位于边框边缘的外围 可起到突出元素的作用 CSS outline属性规定元素轮廓的样式 颜色和宽度 话不多说 来几个例子 看一看 1:在元素周围画线 & ...

  4. php 中的curl

    ① curl上传文件 <?php $postData=array( 'name'=>'123', 'upload'=>'@E:/wamp/www/function/result.zi ...

  5. mysql启动服务时提示"服务名无效"

    1,首先说明一下我的环境,我刚开始是用的XAMPP这个集成的软件,里面安装了apache, mysql,tomcat这些软件,然后通过控制面板对其进行启动关闭的操作,这些操作很方便,但是我就用net ...

  6. Linux 网络编程详解十

    select int select(int nfds, fd_set *readfds, fd_set *writefds,fd_set *exceptfds, struct timeval *tim ...

  7. 【福吧资源网整理】老男孩-python运维6期 不加密

    老男孩-python运维6期 不加密,连夜整理出来分享给大家老男孩的python教程确实不错. 教程目录: 下载地址:http://www.fu83.cn/thread-204-1-1.html  

  8. Datatable删除行的Delete和Remove方法

    在C#中,如果要删除DataTable中的某一行,大约有以下几种办法: 1,使用DataTable.Rows.Remove(DataRow),或者DataTable.Rows.RemoveAt(ind ...

  9. JavaScript中sort方法的一个坑(leetcode 179. Largest Number)

    在做 Largest Number 这道题之前,我对 sort 方法的用法是非常自信的.我很清楚不传比较因子的排序会根据元素字典序(字符串的UNICODE码位点)来排,如果要根据大小排序,需要传入一个 ...

  10. Asp.Net Core-几行代码解决Razor中的嵌套if语句

    MVC开发中,经常会遇到在razor中插入简单的逻辑判断. @if (clientManager.IsAdmin) { if (!Model.Topic.Top) { <a asp-action ...