news 2026/5/1 5:11:25

《P3223 [HNOI2012] 排队》

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《P3223 [HNOI2012] 排队》

题目描述

某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检。他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的)

输入格式

只有一行且为用空格隔开的两个非负整数 n 和 m,其含义如上所述。

输出格式

仅一个非负整数,表示不同的排法个数。注意答案可能很大。

输入输出样例

输入 #1复制

1 1

输出 #1复制

12

说明/提示

对于 30% 的数据 n≤100,m≤100。

对于 100% 的数据 n≤2000,m≤2000。

代码实现:

#include<cstdio> #include<iostream> #include<cmath> #include<algorithm> #include<cstring> #include<cstdlib> #include<cctype> #include<vector> #include<stack> #include<queue> #include<assert.h> using namespace std; #define enter puts("") #define space putchar(' ') #define Mem(a, x) memset(a, x, sizeof(a)) #define In inline typedef long long ll; typedef double db; const int INF = 0x3f3f3f3f; const db eps = 1e-8; const int maxn = 1e6 + 5; In ll rd() { ll res = 0; char c = getchar(), lst = ' '; while(!isdigit(c)) lst = c, c = getchar(); while(isdigit(c)) res = (res << 1) + (res << 3) + c - '0', c = getchar(); if(lst == '-') res = -res; return res; } In void wt(ll x) { if(x < 0) x = -x, putchar('-'); if(x >= 10) wt(x / 10); putchar(x % 10 + '0'); } In void FILE_IO() { #ifndef mrclr freopen("1.in", "r", stdin); freopen("ac.out", "w", stdout); #endif } int n, m; int num[maxn], l = 1; In void mul(int v) { l += 10; int d = 0; for(int i = 0; i < l; ++i) { num[i] = num[i] * v + d; d = num[i] / 10, num[i] %= 10; } while(l > 1 && !num[l - 1]) --l; } int main() { n = rd(), m = rd(); if(m > n + 3) {puts("0"); return 0;} num[0] = 1, l = 1; for(int i = 1; i <= n; ++i) mul(i); for(int i = n + 3 - m + 1; i <= n + 2; ++i) mul(i); mul(n + 1), mul(n * (n + 3) + 2 * m); for(int i = l - 1; i >= 0; --i) wt(num[i]); enter; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/26 16:01:01

C++26来了,你的程序还能跑满CPU吗?亲和性设置成关键瓶颈!

第一章&#xff1a;C26来了&#xff0c;你的程序还能跑满CPU吗&#xff1f;随着C26标准的逐步成型&#xff0c;语言在并发与并行计算方面的支持迎来了显著增强。新的标准库扩展引入了更精细的任务调度机制和内存模型优化&#xff0c;使得开发者能够更高效地压榨现代多核CPU的性…

作者头像 李华
网站建设 2026/4/29 1:08:07

新手避坑指南:lora-scripts常见报错原因及解决方案汇总

新手避坑指南&#xff1a;lora-scripts常见报错原因及解决方案汇总 在消费级 GPU 上训练自己的 AI 模型&#xff0c;听起来像是高手专属&#xff1f;其实不然。如今&#xff0c;借助 LoRA 和自动化脚本工具如 lora-scripts&#xff0c;哪怕你刚入门 PyTorch&#xff0c;也能在 …

作者头像 李华
网站建设 2026/4/23 12:15:20

git commit hook自动化检查lora-scripts代码风格一致性

Git Commit Hook 自动化检查 LoRA-Scripts 代码风格一致性 在 AI 模型训练脚本项目中&#xff0c;你有没有遇到过这样的场景&#xff1f;一个 PR 被反复打回&#xff0c;不是因为逻辑错误&#xff0c;而是“缩进不对”、“import 顺序乱了”、“行太长了”。这些看似琐碎的问题…

作者头像 李华
网站建设 2026/4/27 1:36:55

自动化标注脚本怎么用?lora-scripts内置工具提升效率

自动化标注脚本怎么用&#xff1f;lora-scripts内置工具提升效率 在 AIGC 创作日益普及的今天&#xff0c;越来越多设计师、独立开发者甚至内容创作者都希望训练一个属于自己的风格化模型——比如专属画风的 LoRA&#xff0c;或定制语气回复的聊天机器人。但现实是&#xff0c;…

作者头像 李华
网站建设 2026/4/26 22:36:23

Faststone Capture注册码破解危害警示:支持正版维护生态

Faststone Capture注册码破解危害警示&#xff1a;支持正版维护生态 在数字内容创作与智能工具快速演进的今天&#xff0c;一款高效的截图软件早已不只是“按个 PrintScreen”的替代品。对工程师、设计师和文档撰写者而言&#xff0c;FastStone Capture 这类集截图、录屏、标注…

作者头像 李华
网站建设 2026/4/21 21:30:26

揭秘C++ memory_order之谜:构建无bug多线程程序的关键路径

第一章&#xff1a;C多线程编程中的状态一致挑战在现代高性能计算中&#xff0c;C多线程编程被广泛用于提升程序并发能力。然而&#xff0c;多个线程同时访问共享资源时&#xff0c;极易引发状态不一致问题&#xff0c;如竞态条件&#xff08;Race Condition&#xff09;和数据…

作者头像 李华