BZOJ3198[Sdoi2013]spring

2024-01-30 05:38
文章标签 java spring sdoi2013 bzoj3198

本文主要是介绍BZOJ3198[Sdoi2013]spring,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目大意

懒惰的人不想复制题面了~
给出n(n<10 0000)个六元组,再给出一个k
求有多少对六元组中有恰好k个相同(对应的位置相同)

Sample Input

5 8 2
1 2 5 8
2 5 9 9
5 1 6 2
5 1 1 8
1 2 8 7
2 5 4 9
1 2 1 1
1 4 2 1

Sample Output

13 19

Solution

显然,我们可以枚举哪几位相同,然后使用hash判断相同的个数。
同时,因为要求的是恰好k个相同,所以要减去k+1个相同,加上k+2个相同……
而且,因为一对有n个相同的六元组,对答案贡献会是 Ckn C n k 倍的,所以要乘上去。
我就是因为c[0][0]没有赋初值,调了超级久,然后被大佬一眼看出(%ymw),惨兮兮(╥╯^╰╥)

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<bitset>
using namespace std;#define N 150010
#define P1 1000007
#define P2 998244353
#define LL long longbitset<6> b;int hash[N][3],last[P1],next[N],t[N],a[N][6];
LL ans[7],c[10][10];
int n,m,tot,cnt;int find(int num)
{int x=0;for (int i=0;i<=5;i++)
    if (b[i]==1) x=((LL)x*233+(LL)a[num][i])%P1;int y=0;for (int i=0;i<=5;i++)if (b[i]==1) y=((LL)y*1221+(LL)a[num][i])%P2;for (int i=last[x];i!=0;i=next[i])if (hash[i][1]==y) {hash[i][2]++; return i;}if (last[x]==0) t[++tot]=x;next[++cnt]=last[x];last[x]=cnt;hash[cnt][2]=1;hash[cnt][0]=x; hash[cnt][1]=y;return cnt;
}int main()
{memset(hash,0,sizeof(hash));memset(last,0,sizeof(last));scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)for (int j=0;j<=5;j++)scanf("%d",&a[i][j]);c[1][1]=1; c[1][0]=c[0][0]=1;for (int i=2;i<=6;i++){c[i][0]=1;for (int j=1;j<=i;j++)c[i][j]=c[i-1][j]+c[i-1][j-1];}for (int ii=0;ii<=(1<<6)-1;ii++){b=ii;int s=b.count();if (s<m) continue;for (int l=1;l<=n;l++){int pos=find(l);int t=hash[pos][2];ans[s]+=t-1;}for (int l=1;l<=tot;l++)last[t[l]]=0;tot=0; cnt=0;}LL ss=0;for (int i=m;i<=6;i++)if ((i-m)%2==0) ss+=ans[i]*c[i][m];else ss-=ans[i]*c[i][m];printf("%lld\n",ss);return 0;
}

这篇关于BZOJ3198[Sdoi2013]spring的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/659250

相关文章

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳