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. 20155236范晨歌_Web安全基础实践

    20155236范晨歌_Web安全基础实践 目录 实践目标 WebGoat BurpSuite Injection Flaws Cross-Site Scripting (XSS) 总结 实践目标 ( ...

  2. 【第三方插件】使用Topshelf创建Windows服务

    概述 Topshelf是创建Windows服务的另一种方法,老外的一篇文章Create a .NET Windows Service in 5 steps with Topshelf通过5个步骤详细的 ...

  3. 类加载, 静态变量初始化, String不可变, 泛型使用, 内部类

    1.java变量类型 java变量类型分:基本数据类型变量和Object数据类型变量,变量也是占用者内存的 例如: int i = 3; i这个变量保存的就是整形3, 占32位 Object a = ...

  4. 【转载】VS配置路径和宏

    原文路径:http://blog.csdn.net/puttytree/article/details/7838419 在介绍项目配置之前,先说明两点 1. 项目配置中,最好不要使用相对路径,更不要使 ...

  5. Nuxt.js + koa2 入门

    1. nuxt项目初始化 下面是使用 koa 模板方法初始化一个项目,使用该方法需要将 nuxt 的版本降至1.4.2: 官方 https://zh.nuxtjs.org/guide/installa ...

  6. 同步、异步、回调执行顺序之经典闭包setTimeout分析

    聊聊同步.异步和回调 同步,异步,回调,我们傻傻分不清楚, 有一天,你找到公司刚来的程序员小T,跟他说:“我们要加个需求,你放下手里的事情优先支持,我会一直等你做完再离开”.小T微笑着答应了,眼角却滑 ...

  7. (3)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- Consul服务治理

    Consul是注册中心,服务提供者.服务提供者.服务消费者等都要注册到Consul中,这样就可以实现服务提供者.服务消费者的隔离. 除了Consul之外,还有Eureka.Zookeeper等类似软件 ...

  8. Js_图片切换左右点击

    <!DOCTYPE HTML><html><head><meta http-equiv="Content-Type" content=&q ...

  9. NodeMCU学习(一) : 开始之前的准备

    安装Aduino开发环境 在官网中下载Arduino开发环境,或者在网盘中下载: 网盘地址: https://pan.baidu.com/s/1OjMhYgKOYW69YC2dEwFgyw: 提取码: ...

  10. 【Unity Shader】(三) ------ 光照模型原理及漫反射和高光反射的实现

    [Unity Shader](三) ---------------- 光照模型原理及漫反射和高光反射的实现 [Unity Shader](四) ------ 纹理之法线纹理.单张纹理及遮罩纹理的实现 ...