news 2026/4/21 21:55:41

卡牌游戏(Java/python/JavaScript/C/C++)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
卡牌游戏(Java/python/JavaScript/C/C++)

小明正在尝试一种新的牌游戏。游戏规则只如下:首先,小明拿到一张写有数字m的牌。 然后,他会拿到另外n张牌,上面分别写有不同的数字,牌排成一排。小明的目标是从这排牌中找到一串连续的牌,这些牌上数字的总和可以被 m整除。你的任务是判断小明是否可以完成这个目标。
输入描述
第一行包含两个整数:n和 m。其中n是小明拿到的牌的数量(不包括写有 m 的牌),m 是写在第一张牌上的数字。第二行包含 n个整数,这些整数分别是n张牌上的数字,
输出描述
如果小明可以找到一个连续的牌串,这些牌上数字的和可以被 m 整除,输出“1"。如果找不到符合条件的牌串,输出"0”。

示例1

输入:

6 7
2 12 6 3 5 5

输出:

1

示例2

输入:

10 11
1 1 1 1 1 1 1 1 1 1

输出:

0

问题分析

需要判断是否存在一个连续子数组,其元素之和能被给定的整数m整除。关键在于利用前缀和和模运算的性质来高效解决问题。

解题思路

  1. 前缀和与模运算:计算前缀和数组prefix,其中prefix[i]表示前i个元素的和。若存在prefix[j] % m == prefix[i] % m(其中j > i),则子数组[i+1, j]的和能被m整除。
  2. 哈希表优化:使用哈希表记录前缀和模m的结果首次出现的位置。若同一余数再次出现,说明存在满足条件的子数组。

实现代码

Java
import java.util.HashMap; import java.util.Map; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); int m = scanner.nextInt(); int[] nums = new int[n]; for (int i = 0; i < n; i++) { nums[i] = scanner.nextInt(); } Map<Integer, Integer> modMap = new HashMap<>(); modMap.put(0, -1); int prefixMod = 0; boolean found = false; for (int i = 0; i < n; i++) { prefixMod = (prefixMod + nums[i]) % m; if (modMap.containsKey(prefixMod)) { found = true; break; } modMap.put(prefixMod, i); } System.out.println(found ? "1" : "0"); } }
Python
n, m = map(int, input().split()) nums = list(map(int, input().split())) mod_map = {0: -1} prefix_mod = 0 found = False for i in range(n): prefix_mod = (prefix_mod + nums[i]) % m if prefix_mod in mod_map: found = True break mod_map[prefix_mod] = i print(1 if found else 0)
JavaScript
const readline = require('readline'); const rl = readline.createInterface({ input: process.stdin, output: process.stdout }); let input = []; rl.on('line', (line) => { input.push(line); }).on('close', () => { const [n, m] = input[0].split(' ').map(Number); const nums = input[1].split(' ').map(Number); const modMap = new Map(); modMap.set(0, -1); let prefixMod = 0; let found = false; for (let i = 0; i < n; i++) { prefixMod = (prefixMod + nums[i]) % m; if (modMap.has(prefixMod)) { found = true; break; } modMap.set(prefixMod, i); } console.log(found ? "1" : "0"); });
C++
#include <iostream> #include <unordered_map> #include <vector> using namespace std; int main() { int n, m; cin >> n >> m; vector<int> nums(n); for (int i = 0; i < n; i++) { cin >> nums[i]; } unordered_map<int, int> modMap; modMap[0] = -1; int prefixMod = 0; bool found = false; for (int i = 0; i < n; i++) { prefixMod = (prefixMod + nums[i]) % m; if (modMap.find(prefixMod) != modMap.end()) { found = true; break; } modMap[prefixMod] = i; } cout << (found ? "1" : "0") << endl; return 0; }

代码说明

  • 输入处理:读取输入的nm和数组nums
  • 哈希表初始化:初始化哈希表modMap并预存0: -1,表示前缀和为0的虚拟位置。
  • 遍历数组:计算前缀和的模m结果,检查是否已存在于哈希表中。若存在则直接返回1,否则记录当前余数的位置。
  • 输出结果:根据是否找到满足条件的子数组输出10

这种方法的时间复杂度为O(n),空间复杂度为O(min(n, m)),适用于大规模数据。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 9:16:59

28、利用 OpenSSH 实现安全远程登录

利用 OpenSSH 实现安全远程登录 在管理基于 UNIX 的系统(如运行 Red Hat Enterprise Linux 的系统)时,OpenSSH 等 SSH 工具至关重要。本文将详细介绍如何从 Red Hat Enterprise Linux 系统连接到 SSH 服务器,以及相关工具的使用方法。 1. 连接 SSH 服务器的准备工作 要连…

作者头像 李华
网站建设 2026/4/18 23:48:45

PaddlePaddle图像分类实战:利用git安装第三方工具链支持

PaddlePaddle图像分类实战&#xff1a;利用git安装第三方工具链支持 在智能制造、质检自动化和智慧零售等场景中&#xff0c;图像分类技术正从实验室走向产线。面对日益复杂的模型结构与部署需求&#xff0c;开发者不再满足于“从零写起”的低效模式——如何快速搭建一个稳定、…

作者头像 李华
网站建设 2026/4/16 19:57:59

Redis远程字典服务

RedisRedis&#xff08;全称&#xff1a;Remote Dictionary Server 远程字典服务&#xff09; 开源的非关系数据库(NoSQL)&#xff0c;使用Key-Value键值对来存储数据&#xff1b; 主要功能&#xff1a;作为缓存&#xff0c;替MySQL抗高并发&#xff1b;Redis为什么快&#xff…

作者头像 李华
网站建设 2026/4/16 0:45:20

Amaze File Manager云存储完整配置指南:一键连接Google Drive等主流服务

想要在Android设备上统一管理所有云存储账户&#xff1f;Amaze File Manager的云服务集成功能让你轻松连接Google Drive、Dropbox、OneDrive等主流云平台&#xff0c;实现跨平台文件一站式管理。本指南将详细介绍如何快速配置和使用这些强大的云存储功能。&#x1f680; 【免费…

作者头像 李华
网站建设 2026/4/21 5:09:42

2026毕设ssm+vue基于课程群的实验管理平台论文+程序

本系统&#xff08;程序源码&#xff09;带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景近年来&#xff0c;随着互联网技术的迅猛发展&#xff0c;动漫文化在全球范围内迅速传播&#xff0c;尤其在年轻群体中拥有广泛…

作者头像 李华
网站建设 2026/4/16 16:40:30

2026毕设ssm+vue基于鸿蒙操作系统的新闻app设计论文+程序

本系统&#xff08;程序源码&#xff09;带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景随着互联网技术的快速发展&#xff0c;动漫文化在我国青少年群体中影响力日益增强&#xff0c;成为网络内容消费的重要组成部分…

作者头像 李华