diyiti.cpp/c/pas diyiti.in diyiti.out 2s/256MB

给定两个01串,S,T(下标从0开始)。

支持如下3种操作:

1. 修改S第i位的字符,即0->1,1->0.

2. 修改T第i位的字符,即0->1,1->0.

3. 查询S[a..a+l-1],T[b..b+l-1]的相似度。

相似度定义如下:

s,t两个字符串的相似度=sigma_{i=0}^{|s|-1} sim(s[i],t[i])

sim(a,b) 有四个参数p_{0,0},p_{0,1},p_{1,0},p_{1,1}。 sim(a,b)的返回值为p_{a,b}。

input

第一行一个非空字符串S

第二行一个非空字符串T

第三行一个操作个数Q

接下来Q行,每行为"1 i","2 i"或"3 a b l p_{0,0} p_{0,1} p_{1,0} p_{1,1}"

output

若干行,每行对应每个3操作的答案。

sample in


sample out


10%, |S|,|T|<=1000,Q<=1000
10%, |S|,|T|<=50000,Q<=50000,3操作的p值都为1
10%, |S|,|T|<=50000,Q<=50000,所有操作为3操作且a,b,l相同
20%, |S|,|T|<=50000,Q<=50000,3操作的a,b值为0
50%, |S|,|T|<=100000,Q<=100000,0<=p<=50,由于数据随机生成,可以默认3操作l的期望为|S|/6

压位。。

# include <iostream>
# include <cstdio>
# include <iostream>
# include <cstring>
using namespace std;
const int MAXN=,bit=;
typedef long long ll;
ll a[MAXN],b[MAXN],f1[MAXN],f2[MAXN],f[MAXN];
int len1,len2;
char s[MAXN],pp[MAXN];
void work1()
{
int x; scanf("%d",&x); x++;
a[x]=a[x] ^ ;
for (int i=max(,x-bit);i<=min(x,len1-bit);i++)
f1[i]=f1[i] ^ (<<(x-i));
}
void work2()
{
int x; scanf("%d",&x); x++;
b[x]=b[x] ^ ;
for (int i=max(,x-bit);i<=min(x,len2-bit);i++)
f2[i]=f2[i] ^ (<<(x-i));
}
void work3()
{
int al,bl,len,p1,p2,p3,p4;
scanf("%d%d%d%d%d%d%d",&al,&bl,&len,&p1,&p2,&p3,&p4);
int ans=;
al++; bl++;
for (int i=;i<=len/(bit+);i++) {
ans=ans+f[(f1[al] ^ ((<<(bit+))-))&(f2[bl] ^ ((<<(bit+))-))]*p1;//0 0
ans=ans+f[(f1[al] ^ ((<<(bit+))-))&f2[bl]]*p2; //0 1
ans=ans+f[f1[al] & (f2[bl] ^ ((<<(bit+))-))]*p3;// 1 0
ans=ans+f[f1[al] & f2[bl]]*p4;// 1 1
al=al+(bit+); bl=bl+(bit+);
}
//最后一个压位后的数
for (int i=;i<=len%(bit+)-;i++) {
if ((a[i+al]==)&&(b[i+bl]==)) ans=ans+p1;
if ((a[i+al]==)&&(b[i+bl]==)) ans=ans+p2;
if ((a[i+al]==)&&(b[i+bl]==)) ans=ans+p3;
if ((a[i+al]==)&&(b[i+bl]==)) ans=ans+p4;
}
printf("%d\n",ans);
}
int main()
{
freopen("diyiti.in","r",stdin);
freopen("diyiti.out","w",stdout);
for (int i=;i<=<<(bit+)-;i++)
{
int x=i;
while(x>) {
f[i]=f[i]+;//数i有几个1
x=x & (x-);
}
}
//for (int i=0;i<=20;i++) printf("%d %d\n",i,f[i]);
cin>>s;
for (int i=;i<=strlen(s);i++) pp[i+]=s[i];
len1=strlen(s);
for (int i=;i<=len1;i++) s[i]=pp[i];
for (int i=;i<=len1;i++) a[i]=s[i]-''; //a表示一个大二进制数A cin>>s;
for (int i=;i<=strlen(s);i++) pp[i+]=s[i];
len2=strlen(s);
for (int i=;i<=len2;i++) s[i]=pp[i];
for (int i=;i<=len2;i++) b[i]=s[i]-''; //b表示一个大二进制数B for (int i=;i<=len1-bit;i++)
for (int j=;j<=bit;j++)
f1[i]=f1[i]+a[i+j]<<j; //A每bit位压成一个整数 f1
for (int i=;i<=len2-bit;i++)
for (int j=;j<=bit;j++)
f2[i]=f2[i]+b[i+j]<<j; //B每bit位压成一个整数 f2
int q; scanf("%d",&q);
while (q)
{
int ch; scanf("%d",&ch);
if (ch==) work1();
else if (ch==) work2();
else if (ch==) work3();
q--;
}
return ;
fclose(stdin); fclose(stdout);
}

diyiti.cpp的更多相关文章

  1. 使用“Cocos引擎”创建的cpp工程如何在VS中调试Cocos2d-x源码

    前段时间Cocos2d-x更新了一个Cocos引擎,这是一个集合源码,IDE,Studio这一家老小的整合包,我们可以使用这个Cocos引擎来创建我们的项目. 在Cocos2d-x被整合到Cocos引 ...

  2. Json CPP 中文支持与入门示例

    在每一个Json Cpp自带*.cpp文件头加上: #include "stdafx.h" 将Json Cpp对自带的头文件的引用修改为单引号方式,例如json_reader.cp ...

  3. cpp 调用python

    在用cpp调用python时, 出现致命错误: no module named site  ,  原因解释器在搜索路径下没有找到python库.可以在调用Py_Initialize前,调用 Py_Se ...

  4. nginx+fastcgi+c/cpp

    参考:http://github.tiankonguse.com/blog/2015/01/19/cgi-nginx-three/ 跟着做了一遍,然后根据记忆写的,不清楚有没错漏步骤,希望多多评论多多 ...

  5. APM程序分析-ArduCopter.cpp

    该文件是APM的主文件. #define SCHED_TASK(func, rate_hz, max_time_micros) SCHED_TASK_CLASS(Copter, &copter ...

  6. APM程序分析-AC_WPNav.cpp

    APM程序分析 主程序在ArduCopter.cpp的loop()函数. /// advance_wp_target_along_track - move target location along ...

  7. Dev Cpp 输出中文字符问题

    最近 c++ 上机作业,vc++6.0 挂了没法用,只好用 Dev Cpp 先顶替一下,然而在遇到输出中文字符的时候出现了乱码的情况,但这种情况又非常诡异.于是简单了解了一下写成此博客. [写在前面] ...

  8. 【安卓】aidl.exe E 10744 10584 io_delegate.cpp:102] Error while creating directories: Invalid argument

    这几天在使用.aidl文件的时候eclipse的控制台总是爆出如下提示: aidl.exe E 10744 10584 io_delegate.cpp:102] Error while creatin ...

  9. Identify Memory Leaks in Visual CPP Applications —— VLD内存泄漏检测工具

    原文地址:http://www.codeproject.com/Articles/1045847/Identify-Memory-Leaks-in-Visual-CPP-Applications 基于 ...

随机推荐

  1. C# winform 设置WebBowser 内核版本

    一种是在网页头部 用 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 使用当前浏览器最新 ...

  2. [c#][福利]BTTool种子文件修改工具

    前言 不知道各位看官是否有过类似的经历.好不容易找到一个电影的种子文件,想用百度云的离线下载功能去下载文件,却被百度云无情提示“离线文件因含有违规内容被系统屏蔽无法下载”!假设有这么一个场景,比如最近 ...

  3. EZ 2018 03 16 NOIP2018 模拟赛(四)

    链接:http://211.140.156.254:2333/contest/64 我去掉了一百多分! 这次的题目怎么说呢,特别水,但是就是出现了一些很逗的错误导致炸裂. 最好笑的是SB的不只我一个: ...

  4. [SHOI2012]随机树[期望dp]

    题意 初始 \(1\) 个节点,每次选定一个叶子节点并加入两个儿子直到叶子总数为 \(n\),问叶子节点深度和的平均值的期望以及最大叶子深度的期望. \(n\leq 100\) . 分析 对于第一问, ...

  5. linux下的yum命令详细介绍

    yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器.基於RPM包管理,能够从指定的服务器自动下载RP ...

  6. .NET Core容器化开发系列(零)——计划

    .NET Core相当完善的跨平台特性以及其轻量化的底层接口为我们能顺畅进行微服务开发提供了非常棒的基础. 作为支撑微服务最常见的基础技术--容器化将是本系列的核心内容. 接下来我计划用一个月左右的时 ...

  7. numpy 初识(一)

    基本操作: 读取文件(与pandas读取csv相似): import numpy numpy.genfromtxt("word.txt", delimiter=',', dtype ...

  8. 《unity 3D 游戏开发 第二版》宣雨松 分享 pdf下载

    链接:https://pan.baidu.com/s/1LfRTGUmaE_lGdcmd6QiZkg 提取码:e2sn

  9. 企业落地Kubernetes的问题与对策

    在当今云计算领域,“容器技术”已经从三四年前的炒作期正式进入了产业落地期,而Kubernetes作为容器平台的标准已经得到了广泛应用. Kubernetes从2014年6月由Google宣布开源,到2 ...

  10. Hyperledger Fabric的一些密码学常识

    Hash 哈希(Hash)算法主要作用是将一段任意长度的数据,经过计算转换成一段定长的数据. 这种算法的特性是:几乎不能通过Hash的结果推导出原文.并且几乎没有可能找到两个不同的信息,对两个信息进行 ...