码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Magic Bracelet-【群论】【Burnside引理】【矩阵快速幂】


    https://blog.csdn.net/jisuanji2606414/article/details/126003389?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22126003389%22%2C%22source%22%3A%22jisuanji2606414%22%7D&ctrtid=9U6Tk

    并不像普通群论题,本题不考察polya,考察Burnside引理,并且巧妙的与欧拉函数,DP,矩阵快速幂结合,非常具有综合性和典型性。

    Burnside 引理

    方案数等于各置换不动点的平均数

    这里要特别强调一下不动点,指的是整个圆在旋转之后不变,而非圆上某个点的状态。 

    根据群论循环置换结论

    环每个点旋转i个点,所构成的循环数为gcd(i,n)

    这里需要着重强调一下这  gcd(i,n)个循环究竟长什么样子。

    下图中,相同颜色为一个循环,易知循环长度为3,循环内点必须满足颜色相同才能满足整个圆旋转之后成为一个“不动点”

     由此我们得出第 1个点属于第一个循环,第2个点属于第二个循环,直至第n个点属于第n个循环,第n+1个点属于第一个循环。也就是说,前n个点我们就可以确定这n个循环的状态,也就是整个圆的状态,只要我们求出满足题目排斥要求的n个点的排列方案数,那么整个圆也就被确定了。

    显然可以设 f[i][j]为 第i个点是j颜色的方案数,那么它由上一个点转移而来,转移方程为

    f[i][j] =\sum_{i=1}^{M} f[i-1][k]* m(k,j)  其中m(i,j)是约束条件,0或者1代表是否能够相邻

    但是仅仅满足这种线性关系还不够,第n个点其实是和第1个点相邻的。那么我们可以枚举第1个点的颜色,输出  f[n+1][k]即可,f[n+1][k]完全由f[n][]整体推出,除了去掉与1排斥的条件,都是相同的。这时我们求出了  C(f)  =  f[n+1][k]  ,即不动点数

    根据Burnside定理

    总方案数等于   

     该公式有转化为欧拉函数的步骤,这里暂且将gcd=d时的C(f)记作  C(d)

     这样就可以直接枚举n的因数即可,欧拉函数也可以快速求解,复杂度降低

    下面集中处理C(d)

    直接嵌套循环求DP数组肯定完爆

  • 相关阅读:
    “总是吐槽别人的代码,好像自己很厉害似的”
    centOS7中启动MySQL数据库提示: Failed to start mysqld.service Unit not found
    深度学习入门(二十五)卷积神经网络——多输入多输出通道
    jmeter 简单数据写入器 创建文件失败
    [附源码]Python计算机毕业设计Django社区住户信息管理系统
    1.1.1 算法的概念(第 1 课时)
    【单片机】【数码管】数码管显示
    如何判断一个公司是否为空壳公司
    Java密码库Password4j
    算法-煤球数目
  • 原文地址:https://blog.csdn.net/jisuanji2606414/article/details/126017607
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号