zoukankan      html  css  js  c++  java
  • 【Codeforces】Gym 101156G Non-Attacking Queens 打表

    题意

    求$n imes n$的棋盘上放$3$个皇后使得互相不攻击的方案数


    拓展是$m imes n$棋盘上放$k$皇后,暴力打表找到了公式

    OEIS

    代码

    import java.math.BigInteger;
    import java.util.Scanner;
    
    /**
     * Created by cyuun on 2018/1/24.
     */
    public class Main {
        public static void main(String[] args) {
            BigInteger n,ans;
            Scanner cin = new Scanner(System.in);
            n=cin.nextBigInteger();
            if(n.mod(BigInteger.valueOf(2)).compareTo(BigInteger.valueOf(1))==0) {
                //(n - 1)(n - 3)(2n^4 - 12n^3 + 25n^2 - 14n + 1)/12
                ans=n.subtract(BigInteger.valueOf(1));
                ans=ans.multiply(n.subtract(BigInteger.valueOf(3)));
                BigInteger part1=n.multiply(n).multiply(n).multiply(n).multiply(BigInteger.valueOf(2));
                BigInteger part2=n.multiply(n).multiply(n).multiply(BigInteger.valueOf(12));
                BigInteger part3=n.multiply(n).multiply(BigInteger.valueOf(25));
                BigInteger part4=n.multiply(BigInteger.valueOf(14));
                ans=ans.multiply(part1.subtract(part2).add(part3).subtract(part4).add(BigInteger.valueOf(1)));
                ans=ans.divide(BigInteger.valueOf(12));
            }else {
                //n(n - 2)^2(2n^3 - 12n^2 + 23n - 10)/12
                ans=n;
                ans=ans.multiply(n.subtract(BigInteger.valueOf(2))).multiply(n.subtract(BigInteger.valueOf(2)));
                BigInteger part1=n.multiply(n).multiply(n).multiply(BigInteger.valueOf(2));
                BigInteger part2=n.multiply(n).multiply(BigInteger.valueOf(12));
                BigInteger part3=n.multiply(BigInteger.valueOf(23));
                ans=ans.multiply(part1.subtract(part2).add(part3).subtract(BigInteger.valueOf(10)));
                ans=ans.divide(BigInteger.valueOf(12));
            }
            System.out.println(ans);
        }
    }
    
  • 相关阅读:
    springboot2的redis缓存管理器cacheManager配置,使存入json格式数据
    td内有图片和文字,如何都垂直居中?
    java使用itext导出PDF文本绝对定位
    plsqlDeveloper快速输入(自动替换)配置
    ExtJs4grid合并行
    MySQL存储引擎与体系结构
    Spring AOP
    在IoC容器中装配Bean
    java内存区域与内存溢出异常
    spring IoC(一)
  • 原文地址:https://www.cnblogs.com/ogiso-setsuna/p/8343853.html
Copyright © 2011-2022 走看看