HJ128 小红的双生排列

  • 题目
  • 题解(18)
  • 讨论(11)
  • 排行

中等 通过率:29.71% 时间限制:1秒 空间限制:256M

知识点数论

校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。

描述

小红定义一个++排列++ 是双生排列,当且仅当任意相邻两项之和均为奇数。

现在小红想知道,长度为 nn 的双生排列共有多少种?由于答案可能过大,请对 109+7109+7 取模。

长度为 nn 的++排列++是由 1∼n1∼n 这 nn 个整数、按任意顺序组成的数组,其中每个整数恰好出现一次。例如,{2,3,1,5,4}{2,3,1,5,4} 是一个长度为 55 的排列,而 {1,2,2}{1,2,2} 和 {1,3,4}{1,3,4} 都不是排列,因为前者存在重复元素,后者包含了超出范围的数。

输入描述:

输入一个整数 n(2≦n≦105)n(2≦n≦105) 代表排列的长度。

输出描述:

输出一个整数,代表长度为 nn 的双生排列数量对 109+7109+7 取模的答案。

示例1

输入:

复制代码
3

复制输出:

复制代码
2

复制说明:

复制代码
在这个样例中,长度为 33 的排列有:
∙ ∙ {1,2,3}{1,2,3} 且为双生排列;
∙ ∙ {1,3,2}{1,3,2};
∙ ∙ {2,1,3}{2,1,3};
∙ ∙ {2,3,1}{2,3,1};
∙ ∙ {3,1,2}{3,1,2};
∙ ∙ {3,2,1}{3,2,1} 且为双生排列。
cpp 复制代码
#include <iostream>
using namespace std;
#define MOD 1000000007;
int main() {
    int n;
    cin >> n;
    //当且仅当任意相邻两项之和均为奇数
    //奇数 + 偶数 为奇数 ----》奇 偶 数相间排列
    //n为偶数时 奇数偶数  偶数奇数都行
    //n为奇数时 只能奇数偶数  因为奇数多一个 且每个整数恰好出现一次
    
    long long ans = 1;
    int odds = (n + 1) / 2;  // 奇数个数
    int evens = n / 2;       // 偶数个数
    
    // 计算奇数排列数
    for (int i = 1; i <= odds; ++i)
        ans = ans * i % MOD;
    
    // 计算偶数排列数
    for (int i = 1; i <= evens; ++i)
        ans = ans * i % MOD;
    
    // 当n为偶数时两种模式都有效,需要乘2
    if (n % 2 == 0)
        ans = ans * 2 % MOD;
    
    cout << ans;



}
// 64 位输出请用 printf("%lld")
相关推荐
壹号用户16 小时前
C++入门(引用)
数据结构·c++
lcj251116 小时前
【list】手撕C++ list!从0到1实现双向链表,迭代器、const迭代器、模板全解析,面试官都惊呆了!
c++·笔记·链表·list
8Qi817 小时前
LeetCode 518:零钱兑换 II(Coin Change II)—— 题解 ✅
java·算法·leetcode·动态规划·完全背包
计算机安禾17 小时前
【算法分析与设计】第49篇:算法博弈论与机制设计
人工智能·算法·机器学习
玖釉-17 小时前
Vulkan Specialization Constants 详解:在“运行时配置”和“编译期优化”之间取得平衡
c++·windows·图形渲染
05候补工程师17 小时前
【408 数据结构】图论核心算法(拓扑/关键路径)与二叉搜索树精髓夺分笔记
数据结构·经验分享·笔记·考研·算法·图论
AC赳赳老秦17 小时前
OpenClaw+MySQL 深度应用:自动生成建表语句、索引优化建议与数据迁移脚本
开发语言·数据库·人工智能·python·mysql·算法·openclaw
奔袭的算法工程师17 小时前
论文解读--BEV-radar:: bidirectional radar-camera fusion for 3D object detection
人工智能·算法·目标检测·计算机视觉·自动驾驶·信号处理
-FxYaM-17 小时前
【UE】渲染框架学习路径-初次修改源码
服务器·网络·c++·windows·ue5·unreal engine
郝学胜-神的一滴17 小时前
Qt 高级开发 025:打造优雅界面的艺术与高效重构之道
开发语言·c++·qt·程序人生·重构·软件构建·用户界面