A:链接:https://ac.nowcoder.com/acm/contest/393/A

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld

题目描述

给定两个等长的由小写字母构成的串 A,BA,B,其中 |A|=|B|=n 。

现在你需要求出一个子区间 [l,r]使得 LCP(A[l,r],B[l,r])×LCS(A[l,r],B[l,r])+LCP(A[l,r],B[l,r])+LCS(A[l,r],B[l,r]) 最大,并输出这个值。

LCP(S,T)表示S和T的最长公共前缀,LCS(S,T)表示S和T的最长公共后缀。

输入描述:

第一行一个字符串 AA。

第二行一个字符串 BB 。

输出描述:

一行一个整数,表示答案。
示例1

输入

aaabbbcccddd
aaaddddddddd

输出

15

说明

选择 l=1,r=12  是一种可行的最优解。

备注:

对于所有数据,保证 n≤200000 ,串 A,B仅由小写字母构成。

思路:一眼看是最长公共前缀和最长公共后缀。但是稍微想一下,其实只需要求一次最长公共前缀就行了,因为无论怎么样对于一段连续字符串来说,最长前缀和最长后缀是一样的。
    比如说aaabab和aaaccc,最优情况是选前三个字母aaa。
#include<bits/stdc++.h>
using namespace std;
#define LL long long
const LL mod = ;
int dp[];
int main(){
string s1,s2;
cin>>s1>>s2;
memset(dp,,sizeof(dp));
int a = ,b = ;
for(int i = ; i <= s1.size() ; i ++){
if(s1[i-] == s2[i-]){
dp[i] = dp[i-]+;
}else{
dp[i] = ;
}
a = max(a,dp[i]);
}
LL ans = a*a*1LL + 2LL*a;
printf("%lld\n",ans);
}/*
aaabbbddccdd
aaaddddddddd
*/
B:链接:https://ac.nowcoder.com/acm/contest/393/B
来源:牛客网
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 524288K,其他语言1048576K
64bit IO Format: %lld

题目描述

注意本题有模数
给定一个 长度为 n 的序列 { a } ,求:
max1≤i≤j≤n{(ai⊕ai+1⊕⋯⊕aj)+(ai+ai+1+⋯+aj)}mod100000007
其中 ⊕ 表示异或

输入描述:

第一行一个整数 n 。
第二行 n 个整数,表示 ai 。

输出描述:

一行一个整数 ans ,表示答案。
示例1

输入

3
1 2 3

输出

6

说明

我们 显然需要将所有的数字都选上显然需要将所有的数字都选上,此时 ans=(1⊕2⊕3)+1+2+3=6 。

备注:

对于所有的数据,保证 1≤n≤3×105,0≤ai<220 。

样例:想不到吧,你的做法至少能过样例!

思路:没啥好说的,对于一个数a_i,即使前面出现过a_i这个数,大不了就是异或等于0,但是会再加上a_i,对ans贡献肯定是增大的。所以选所有数就好啦。

#include<bits/stdc++.h>
using namespace std;
#define LL long long
const LL mod = ;
int main(){
int n;
scanf("%d",&n);
LL s1 = ,s2 = ;
for(int i = ; i < n ; i ++){
LL x;
scanf("%lld",&x);
s1 += x;
s1 %=mod;
s2 ^= x;
s2 %= mod;
}
printf("%lld\n",(s1+s2+mod)%mod);
}

C:链接:https://ac.nowcoder.com/acm/contest/393/C
来源:牛客网

时间限制:C/C++ 2秒,其他语言4秒
空间限制:C/C++ 524288K,其他语言1048576K
64bit IO Format: %lld

题目描述

给定m个长为n的序列a1,a2,…,am。

小Z想问你:

n∑i1=1n∑i2=1…n∑im=1SUM(a1,i1,a2,i2,…,am,im)  mod1000000007
其中SUM(一个序列)SUM(一个序列)表示这个序列中所有不同的数的和,相当于先sort,unique再求和。

输入描述:

第一行两个整数n,m。

接下来m行,每行n个整数,第i行第j个表示ai,jai,j

输出描述:

一行一个整数,表示答案。
示例1

输入

2 3
1 2
2 3
1 3

输出

36

说明

一共有8种情况:

SUM(1,2,1)=3 SUM(1,2,3)=6 SUM(1,3,1)=4 SUM(1,3,3)=4
SUM(2,2,1)=3 SUM(2,2,3)=5 SUM(2,3,1)=6 SUM(2,3,3)=5
把所有数字结果加起来就是36。

备注:

对于所有100%100%的数据,有1≤n,m≤2000,0≤ai,j≤10^9

题意:求这个式子的和,不难理解,按样例来说,就是每行的2个选1个,组成的所有情况。就是2^3=8种。然后按照题目给的意思计算。
思路:待更新。

牛客练习赛42(A,B)的更多相关文章

  1. 牛客练习赛42 C 出题的诀窍 (贡献,卡常)

    牛客练习赛42 C 出题的诀窍 链接:https://ac.nowcoder.com/acm/contest/393/C来源:牛客网 题目描述 给定m个长为n的序列a1,a2,-,ama_1 , a_ ...

  2. 牛客练习赛42 C 出题的诀窍

    题目链接:https://ac.nowcoder.com/acm/contest/393/C 这个题就是对于每个数算贡献,如果有相同的数,只计算先出现的数的贡献 对于数x,若它在前i行的数目分别为a1 ...

  3. 牛客练习赛42 C 反着计算贡献

    https://ac.nowcoder.com/acm/contest/393/C 题意 给你一个矩阵, 每次从每行挑选一个数,组成一个排列,排列的和为不重复数字之和,求所有排列的和(n,m<= ...

  4. 牛客练习赛42 出题的诀窍(数学+hash)

    出题的诀窍 题目链接:https://ac.nowcoder.com/acm/contest/393/C 题解: 由于他是在每一行选取一个元素,然后纵向来比较,这里行的顺序是不会影响的,所以我们将每一 ...

  5. 牛客练习赛42 A 字符串

    题目描述 给定两个等长的由小写字母构成的串 A,BA,B,其中 |A|=|B|=n|A|=|B|=n. 现在你需要求出一个子区间 [l,r][l,r] 使得 LCP(A[l,r],B[l,r])×LC ...

  6. 牛客练习赛42 E.热爆了

    这可能是全场最长的一份代码 问的其实是对于关键点的斯坦纳树大小 考虑补集转化,不合法的点就是它的子树中没有关键点的点和斯坦纳树根的祖先 树根不难求,关键点中dfs序最大最小点的LCA就是了 问题在前者 ...

  7. 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B

    牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...

  8. 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D

    目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...

  9. 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A

    牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...

随机推荐

  1. 备忘:EBS参考链接

    帮助手册查阅网址http://docs.oracle.com/cd/V46499_01/current/html/docset.html  官方 http://www.oracleappshub.co ...

  2. zabbix_agent添加到系统服务启动(八)

    Centos6.5上安装了zabbix_agent后,需要把zabbix_agent添加到系统服务启动,要不然每次要一长串路径再启动,挺麻烦的. 步骤: 1)拷贝zabbix解压包里的zabbix_a ...

  3. ehcache讲解及实例

    ehcache讲解及实例https://www.cnblogs.com/coprince/p/5984816.html 有些情形下注解式缓存是不起作用的:同一个bean内部方法调用,子类调用父类中有缓 ...

  4. nginx配置http强制跳转https

    nginx配置http强制跳转https 网站添加了https证书后,当http方式访问网站时就会报404错误,所以需要做http到https的强制跳转设置. 一.采用nginx的rewrite方法 ...

  5. 关于Verilog中begin-end & fork-join

     转载:http://blog.sina.com.cn/s/blog_6c7b6f030101cpgt.html begin-end and fork-join are used to combi ...

  6. 5.IAP - FLASH

    一.Flash与时钟系统的关系            STM32系统时钟:                 HSE 高速外部时钟,电路上焊接的外部时钟,一般是4Mhz-16Mhz,板子上的是8Mhz ...

  7. 如何将maven依赖项打进jar包,将一个完整的项目打进jar包

    目的:我的目的就是将项目所有的文件,包括pom文件中依赖的jar包都打进一个jar包里面. 过程:将下面的内容放到pom文件里面. </dependencies> <build> ...

  8. C++Primer第五版——习题答案详解(十)

    习题答案目录:https://www.cnblogs.com/Mered1th/p/10485695.html 第11章 关联容器 练习11.3 #include<iostream> #i ...

  9. JDBC 中preparedStatement和Statement区别

    一.概念 PreparedStatement是用来执行SQL查询语句的API之一,Java提供了 Statement.PreparedStatement 和 CallableStatement三种方式 ...

  10. IDEA2016 maven项目配置Junit

    添加插件:File->Settings->Plugins 设置生成模式:File->Settings->Other Settings 修改模板:File->Setting ...