卢卡斯定理判断组合数奇偶(Codeforces Round 1006 (Div. 3)——F)

news2025/3/3 7:16:10

文章目录

    • 组合数奇偶判断
      • 题意
      • 思路
      • 综上

组合数奇偶判断

【用杨辉三角阐释Lucas定理】https://www.bilibili.com/video/BV14F411P7ES?vd_source=67186f29c3efb728bcff34035cf5aba2

这个视频可以简单的领会一下精神,卢卡斯定理也就是用于组合数取模。

  • 奇偶性通过对2取模来判断。

为什么提到“奇偶”“对2取摸”“杨辉三角”“卢卡斯定理”?

这就要引入一道题:
Problem - F - Codeforces

榜单清一色的
cout<<(((n-1)&i)==i?k:0)<<’ ';

实在捉摸不透,因而来解释一番

题意

求三角形第n行的数据。

三角形定义如下:

  • 在i行有i个整数
  • 第一行中的单个整数是 k k k 。(k的值无关紧要,只考虑01)

T i , j = { T i − 1 , j − 1 ⊕ T i − 1 , j , if  1 < j < i T i − 1 , j , if  j = 1 T i − 1 , j − 1 , if  j = i T_{i,j} = \begin{cases} T_{i-1,j-1} \oplus T_{i-1,j}, &\textrm{if } 1 < j < i \\ T_{i-1,j}, &\textrm{if } j = 1 \\ T_{i-1,j-1}, &\textrm{if } j = i \end{cases} Ti,j= Ti1,j1Ti1,j,Ti1,j,Ti1,j1,if 1<j<iif j=1if j=i

思路

  1. 异或某种意义上来讲,是不进位的二进制加法

​ 根据三角形定义,易知:此三角形正是杨辉三角对2取模

  1. 由于杨辉三角和二项式、组合数的关系。只需求 C n − 1 i C_{n-1}^{i} Cn1i%2, 0为0,1为k

  2. 卢卡斯定理用于p(质数)较小的组合数取模

    根据Lucas定理,对于质数p(在这里p=2),组合数C(n, k)模p可以表示为一下两种形式(本文主要围绕第二种):
    C n m = C n p m p ⋅ C n % p m % p % p C_{n}^{m}=C_\frac{n}{p}^\frac{m}{p}\cdot C_{{n\%p}}^{m\%p} \%p Cnm=CpnpmCn%pm%p%p

C ( n , m ) ≡ ∏ i = 0 r C ( n i , m i ) ( m o d p ) C(n, m) \equiv \prod_{i=0}^{r} C(n_i, m_i) \pmod{p} C(n,m)i=0rC(ni,mi)(modp)

其中,n和m分别表示为p进制数(在这里是二进制),即 n = ∑ i = 0 r n i ⋅ 2 i 和 m = ∑ i = 0 r m i ⋅ 2 i n = \sum_{i=0}^{r} n_i \cdot 2^i 和 m = \sum_{i=0}^{r} m_i \cdot 2^i n=i=0rni2im=i=0rmi2i

总结: C ( n , m ) ( m o d 2 ) C(n, m)\pmod{2} C(n,m)(mod2)等于n的二进制表示中每个位上的数字与k的二进制表示中对应位上的数字进行“与”操作的结果的乘积。

  • 由于我们考虑的是模2的情况,组合数 C ( n i , m i ) C(n_i, m_i) C(ni,mi)模2只有两种结果:0或1。而 C ( n i , m i ) C(n_i, m_i) C(ni,mi)模2为1当且仅当 n i > = m i n_i >= m_i ni>=mi

即, C 0 0 和 C 1 1 和 C 1 0 C_{0}^{0}和C_{1}^{1}和C_{1}^{0} C00C11C10=1, C 0 1 C_{0}^{1} C01为0

  • 因此,C(n, m)模2为1当且仅当n和k的二进制表示中对应的每一位都满足 n i > = m i n_i >= m_i ni>=mi,这等价于 n i 和 m i n_i和m_i nimi的“与”操作结果为1

综上

(n-1)&i==i 表示组合数 C n − i i C_{n-i}^{i} Cnii为奇数,反之,为偶数
若想了解公式一求解组合数,请转:
求组合数(递推法、乘法逆元、卢卡斯定理、分解质因数)_分解质因数求组合数-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2308287.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LLM中的Benchmark是什么

LLM中的Benchmark是什么 “DeepSeek推动价值重估Benchmark” DeepSeek这家公司或其相关技术的发展,促使Benchmark这家机构对相关资产或企业的价值进行重新评估。“Benchmark”在这里是一家研究机构或金融分析机构。 “Benchmark”常见的意思是“基准;水准点,基准点”,作…

梯度下降法(Gradient Descent) -- 现代机器学习的血液

梯度下降法(Gradient Descent) – 现代机器学习的血液 梯度下降法是现代机器学习最核心的优化引擎。本文从数学原理、算法变种、应用场景到实践技巧&#xff0c;用三维可视化案例和代码实现揭示其内在逻辑&#xff0c;为你构建完整的认知体系。 优化算法 一、梯度下降法的定义…

微服务学习(2):实现SpringAMQP对RabbitMQ的消息收发

目录 SpringAMQP是什么 为什么采用SpringAMQP SpringAMQP应用 准备springBoot工程 实现消息发送 SpringAMQP是什么 Spring AMQP是Spring框架下用于简化AMQP&#xff08;高级消息队列协议&#xff09;应用开发的一套工具集&#xff0c;主要针对RabbitMQ等消息中间件的集成…

StarRocks 在爱奇艺大数据场景的实践

作者&#xff1a;林豪&#xff0c;爱奇艺大数据 OLAP 服务负责人 小编导读&#xff1a; 本文整理自爱奇艺工程师在 StarRocks 年度峰会的分享&#xff0c;介绍了爱奇艺 OLAP 引擎演化及引入 StarRocks 后的效果。 在广告业务中&#xff0c;StarRocks 替换 ImpalaKudu 后&#x…

JAVA入门——IO流

一、了解File类 这个类里面提供了一些文件相关的方法&#xff0c;了解即可&#xff0c;方法有很多&#xff0c;不好背下面这个是最常用的只能对文件本身操作&#xff0c;不能读取数据 public File[] listFiles();//获取当前路径下的所有内容 注意&#xff1a;如果是需要权限才…

Spring Boot 流式响应豆包大模型对话能力

当Spring Boot遇见豆包大模型&#xff1a;一场流式响应的"魔法吟唱"仪式 一、前言&#xff1a;关于流式响应的奇妙比喻 想象一下你正在火锅店点单&#xff0c;如果服务员必须等所有菜品都备齐才一次性端上来&#xff0c;你可能会饿得把菜单都啃了。而流式响应就像贴…

【多模态】Magma多模态AI Agent

1. 前言 微软杨建伟团队&#xff0c;最近在AI Agent方面动作连连&#xff0c;前两天开源了OmniParser V2&#xff0c;2月26日又开源了Magma&#xff0c;OmniParser专注在对GUI的识别解析&#xff0c;而Magma则是基于多模态技术&#xff0c;能够同时应对GUI和物理世界的交互&…

DeepSeek掘金——DeepSeek R1驱动的PDF机器人

DeepSeek掘金——DeepSeek R1驱动的PDF机器人 本指南将引导你使用DeepSeek R1 + RAG构建一个功能性的PDF聊天机器人。逐步学习如何增强AI检索能力,并创建一个能够高效处理和响应文档查询的智能聊天机器人。 本指南将引导你使用DeepSeek R1 + RAG构建一个功能性的PDF聊天机器人…

DeepSeek在PiscTrace上完成个性化处理需求案例——光流法将烟雾动态可视化

引言&#xff1a;PiscTrace作为开放式的视图分析平台提供了固定格式的类型参数支持个性化定制处理需求&#xff0c;本文一步步的实现光流分析按照不同需求根据DeepSeek的代码处理视频生成数据。 光流法&#xff08;Optical Flow&#xff09;是一种基于图像序列的计算机视觉技术…

explore与explode词源故事

英语单词explore来自古法语&#xff0c;源自拉丁语&#xff0c;由前缀ex-&#xff08;出来&#xff09;加词根plor-&#xff08;叫喊&#xff09;以及末尾的小尾巴-e组成&#xff0c;字面意思就是“喊出来&#xff0c;通过叫喊声赶出来”。它为什么能表示“探索”呢&#xff1f…

LeeCode题库第三十七题

37.解数独 项目场景&#xff1a; 编写一个程序&#xff0c;通过填充空格来解决数独问题。 数独的解法需 遵循如下规则&#xff1a; 数字 1-9 在每一行只能出现一次。数字 1-9 在每一列只能出现一次。数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。&#xff08;请…

小红书自动评论

现在越来越多的人做起来小红书&#xff0c;为了保证自己的粉丝和数据好看&#xff0c;需要定期养号。 那么养号除了发视频外&#xff0c;还需要积极在社区互动&#xff0c;比如点赞、评论等等&#xff0c;为了节省时间&#xff0c;我做了一个自动化评论工具。 先看效果 那这个是…

OpenCV图像认知(一)

OpenCV&#xff1a; 是由Intel公司俄罗斯团队发起并参与和维护的一个计算机视觉处理开源软件库&#xff0c;支持与计算机视觉和机器学习相关的众多算法 OpenCV-Python&#xff1a; OpenCV-Python是一个Python绑定库&#xff0c;旨在解决计算机视觉问题。 Python是一种由Gui…

Qt6.8编译项目找不到文件——6.8.2\msvc2022_64\include\QtWidgets\QMainWindow does not exist.

问题&#xff1a;Error: dependent ‘…\Qt6.8.2\6.8.2\msvc2022_64\include\QtWidgets\QMainWindow’ does not exist. jom: D:\Temp\untitled1\build\Makefile [release] Error 2 20:20:43: 进程"D:\ProgramFiles\Develop\Qt6.8.2\Tools\QtCreator\bin\jom\jom.exe"…

发展中的脑机接口:SSVEP特征提取技术

一、简介 脑机接口&#xff08;BCI&#xff09;是先进的系统&#xff0c;能够通过分析大脑信号与外部设备之间建立通信&#xff0c;帮助有障碍的人与环境互动。BCI通过分析大脑信号&#xff0c;提供了一种非侵入式、高效的方式&#xff0c;让人们与外部设备进行交流。BCI技术越…

绕过密码卸载360终端安全管理系统

一不小心在电脑上安装了360终端安全管理系统&#xff0c;就会发现没有密码&#xff0c;就无法退出无法卸载360&#xff0c;很容易成为一个心病&#xff0c;360终端安全管理系统&#xff0c;没有密码&#xff0c;进程无法退出&#xff0c;软件无法卸载&#xff0c;前不久听同事说…

Java数据结构第十五期:走进二叉树的奇妙世界(四)

专栏&#xff1a;Java数据结构秘籍 个人主页&#xff1a;手握风云 目录 一、二叉树OJ练习题&#xff08;续&#xff09; 1.1. 二叉树的层序遍历 1.2. 二叉树的最近公共祖先 1.3. 从前序与中序遍历序列构造二叉树 1.4. 从中序与后序遍历序列构造二叉树 1.5. 根据二叉树创建…

Typora的Github主题美化

[!note] Typora的Github主题进行一些自己喜欢的修改&#xff0c;主要包括&#xff1a;字体、代码块、表格样式 美化前&#xff1a; 美化后&#xff1a; 一、字体更换 之前便看上了「中文网字计划」的「朱雀仿宋」字体&#xff0c;于是一直想更换字体&#xff0c;奈何自己拖延症…

Cursor配置MCP Server

一、什么是MCP MCP&#xff08;Model Context Protocol&#xff09;是由 Anthropic&#xff08; Claude 的那个公司&#xff09; 推出的开放标准协议&#xff0c;它为开发者提供了一个强大的工具&#xff0c;能够在数据源和 AI 驱动工具之间建立安全的双向连接。 举个好理解…

定时器之输入捕获

输入捕获的作用 工作机制​ 输入捕获通过检测外部信号边沿&#xff08;上升沿/下降沿&#xff09;触发计数器&#xff08;CNT&#xff09;值锁存到捕获寄存器&#xff08;CCRx&#xff09;&#xff0c;结合两次捕获值的差值计算信号时间参数。 ​脉冲宽度测量&#x…