BISHI69 [HNOI2008]越狱

这个问题可以通过计算"总方案数"减去"不越狱方案数"来得出结果。

总分配方案数

每个房间有 M M M 种宗教选择,共有 N N N 个房间。

总数 = M × M × ⋯ × M = M N M \times M \times \dots \times M = M^N M×M×⋯×M=MN。

不越狱方案数 :

第 1 个房间有 M M M 种选择;

第 2 个房间为了不与第 1 个重复,有 M − 1 M-1 M−1 种选择;

第 3 个房间为了不与第 2 个重复,有 M − 1 M-1 M−1 种选择;

以此类推,剩下的 N − 1 N-1 N−1 个房间每个都有 M − 1 M-1 M−1 种选择。

不越狱总数 = M × ( M − 1 ) N − 1 M \times (M-1)^{N-1} M×(M−1)N−1。

可能发生越狱的方案数

越狱方案 = 总方案数 - 不越狱方案数
结果 = M N − M × ( M − 1 ) N − 1 M^N - M \times (M-1)^{N-1} MN−M×(M−1)N−1

流程图

代码实现

java 复制代码
 private static final long MOD = 100003L;

    public static void main(String[] args) throws IOException {
        // 使用BufferedReader读取输入,PrintWriter输出结果
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));

        String[] str = br.readLine().split("\\s+");
        long M = Long.parseLong(str[0]);
        long N = Long.parseLong(str[1]);
        long total = mypower(M, N, MOD);
        long safe = M * mypower(M - 1, N - 1, MOD)%MOD;
        long ans = (total-safe+MOD)%MOD;

        out.println(ans);

        out.flush();
        out.close();
        br.close();
    }

    private static long mypower(long base, long exp, long mod) {

        long ans = 1 % mod;
        while (exp > 0) {

            if (exp % 2 == 1) {
                ans = (ans * base) % mod;
            }

            base = (base * base) % mod;
            exp /= 2;
        }

        return ans;
    }
相关推荐
雪碧聊技术几秒前
上午题_计算机系统
java·开发语言
纤纡.几秒前
解锁 Python 实用编程技巧:线程、视觉识别、正则匹配与装饰器实战
开发语言·python·深度学习·opencv
t***5446 分钟前
如何在Dev-C++中配置Clang编译器
开发语言·c++
逆境不可逃7 分钟前
一篇速通RabbitMQ (从入门到生产实战:核心原理、高级特性与 Spring Boot 集成全解)
开发语言·后端·ruby
黄林晴10 分钟前
Kotlin 2.4.0-Beta2 发布,语法与多平台能力全线革新
android·kotlin
恋猫de小郭10 分钟前
Bun 官方将正式支持 Android,Claude Code 未来可以直接在手机上跑
android·前端·ai编程
yuanpan11 分钟前
Python Pandas 库入门:介绍与基本使用教程
开发语言·python·pandas
月落归舟11 分钟前
JAVA基础之反射
java·反射
t***54413 分钟前
Dev-C++ 中使用 Clang 调试有哪些常见问题
开发语言·c++
极客先躯15 分钟前
高级java每日一道面试题-2025年11月15日-行业专题[LangChain4j]-如何实现热点事件的实时分析和推送?
java·数据库·langchain·突发性与不可预测性·信息碎片化与多源重复·情绪驱动与谣言风险·推送的精准性与合规性