同程旅行笔试 同程旅行笔试题 0924

笔试时间:2024年09月24日 秋招

历史笔试传送门:2023秋招笔试合集

第一题

题目:小红的方案数

小红想构造一个长n宽m的数组,满足第奇数个元素都是奇数,第偶数个元素都是偶数(即n和m的奇偶性相同,数组下标从1开始计算)。且每个元素都在[1, m]之间。小红想知道一共有多少种不同的方案?答案请对10^9 + 7取模。

输入描述

第一行两个正整数n, m。

输出描述

输出一个数,代表构造的方案数。

样例输入

3 3

样例输出

6

参考题解

我们需要计算长度为n的数组中,奇数位置和偶数位置的元素各自有多少种选择,然后将这些选择相乘得到总的方案数。

C++:[此代码未进行大量数据的测试,仅供参考]

#include <iostream>
using namespace std;

const int MOD = 1000000007;

long fastPow(long base, long exponent) {
    long result = 1;
    while (exponent > 0) {
        if (exponent & 1) {
            result = (result * base) % MOD;
        }
        base = (base * base) % MOD;
        exponent >>= 1;
    }
    return result;
}

int main() {
    int n, m;
    cin >> n >> m;

    long oddCount = (n + 1) / 2;
    long evenCount = n / 2;
    long oddChoices = (m + 1) / 2;
    long evenChoices = m / 2;

    long oddResult = fastPow(oddChoices, oddCount);
    long evenResult = fastPow(evenChoices, evenCount);

    long result = (oddResult * evenResult) % MOD;
    cout << result << endl;

    return 0;
}

Java:[此代码未进行大量数据的测试,仅供参考]

import java.util.Scanner;

public class Main {
    private  static  final int MOD =1000000007;
 public static void main(String[] args) {
   
    Scanner scanner = new Scanner(System.in);
    int n = scanner.nextInt();
    int m = scanner.nextInt();
    scanner.close();

    long oddCount = (n + 1) / 2;
    long evenCount = n / 2;
    long oddChoices = (m + 1) / 2;
    long evenChoices = m / 2;

    long oddResult = fastPow(oddChoices, oddCount);
    long evenResult = fastPow(evenChoices, evenCount);

    long result = (oddResult * evenResult) % MOD;
    System.out.println(result);
}

private static long fastPow(long base, long exponent) {
    long result = 1;
    while (exponent > 0) {
        if ((exponent & 1) == 1) {
            result = (result * base) % MOD;
        }
        base = (base * base) % MOD;
        exponent >>= 1;
    }
    return result;
  }
}

Python:[此代码未进行大量数据的测试,仅供参考]

MOD = 1000000007

def fast_pow(base, exponent):
    result = 1
    while exponent > 0:
        if exponent & 1:
            result = (result * base) % MOD
        base = (base * base) % MOD
        exponent >>= 1
    return result

if __name__ == "__main__":
    n, m = map(int, input().split())

    odd_count = (n + 1) // 2
    even_count = n // 2
    odd_choices = (m + 1) // 2
    even_choices = m // 2

    odd_result = fast_pow(odd_choices, odd_count)
    even_result = fast_pow(even_choices, even_count)

    result = (odd_result * even_result) % MOD
    print(result)

第二题

题目:小红的密码

小红准备在一个网站注册一批账号和密码。已知当小红进行注册时,该网站会给出以下提示:1.用户名为6-12的字符串,且必须含有英文字母(大小写均可)和数字。2.用户名必须没有被注册过。

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

2024 BAT笔试合集 文章被收录于专栏

持续收录字节、腾讯、阿里、美团、美团、拼多多、华为等笔试题解,包含python、C++、Java多种语言版本,持续更新中。

全部评论
佬约面了吗
点赞 回复 分享
发布于 09-25 22:01 湖北
第一题的样例输出是不是有问题
点赞 回复 分享
发布于 10-09 13:58 江苏

相关推荐

不愿透露姓名的神秘牛友
10-24 19:33
投递传音控股等公司10个岗位 > 你都收到了哪些公司的感谢信?
点赞 评论 收藏
分享
点赞 2 评论
分享
牛客网
牛客企业服务