《深入浅出进阶篇》洛谷P3197 越狱——集合

2023-12-09 23:53

本文主要是介绍《深入浅出进阶篇》洛谷P3197 越狱——集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 洛谷P3197 越狱

题目大意:

监狱有 n 个房间,每个房间关押一个犯人,有 m 种宗教,每个犯人会信仰其中一种。如果相邻房间的犯人的宗教相同,就可能发生越狱,求有多少种状态可能发生越狱。

答案对100,003 取模。

对于 100% 的数据,保证1≤m≤10^8,1≤n≤10^12。

 学啥用啥!!!

要求有多少种状态可能发生越狱,我们可以求所有的安排牢房的状态 ,也就是全集。

 然后再算出所有的不会越狱的状态,也就是集合A。

用全集减去集合A,得到补集,这就是答案。

全集如何求?   

由乘法原理可知,每个牢房都可以安排m种宗教,也就是有m种选择,一共有n个牢房,那么全集就是:m^{n}

接下来我们要求,所有不会越狱的状况,集合A。

也就是要使得每个相邻的房间宗教不同。

第一个房间的选择有m种,第二个房间的选择只要满足不和前面的房间相同即可,m-1种

第三个房间只要满足与第二个房间不同,也就是m-1种。

这样下来,每个房间都与自己前一个房间的宗教不同,从而使得每个相邻的房间宗教不同。

答案就是  m \cdot (m-1)^{n-1}

所以最终答案就是      m^{n}-m \cdot (m-1)^{n-1}  mod ( 100003 )

用快速幂即可

(千万记住先输入m再输入n,我被这个卡了好久!!!!)

然后别忘了特判   

m^{n}-m \cdot (m-1)^{n-1} 快速幂之和可能会小于0,再加上100003即可

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<cstdio>
#include<cmath>
#include<string>
#include<cstring>
#include<string>
#include<algorithm>
#include<vector>
#include<cctype>
#include<map>
#include<set>
#include<queue>
#include<numeric>
#include<iomanip>
using namespace std;
const long long MOD = 100003;
typedef long long ll;
ll qpow(ll m, ll n) {ll s = 1;while (n) {if (n & 1)s = s * m % MOD;m = m * m % MOD;n >>= 1;}return s;
}
ll n, m,ans,cns,bns;int main() {cin >> m >> n;ans = qpow(m, n);bns = (m * qpow(m - 1, n - 1))%MOD;cns = (ans - bns)%MOD;if (cns < 0)cns += MOD;cout << cns;
}

这篇关于《深入浅出进阶篇》洛谷P3197 越狱——集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

Java集合中的List超详细讲解

《Java集合中的List超详细讲解》本文详细介绍了Java集合框架中的List接口,包括其在集合中的位置、继承体系、常用操作和代码示例,以及不同实现类(如ArrayList、LinkedList和V... 目录一,List的继承体系二,List的常用操作及代码示例1,创建List实例2,增加元素3,访问元

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.