news 2026/3/12 17:59:59

卡牌游戏(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/3/11 8:54:28

Foundation 模态框

Foundation 模态框&#xff08;Reveal / Modal&#xff09;详解&#xff08;超级完整版&#xff0c;一次讲透&#xff09; 我们继续你的 Foundation 系列&#xff0c;今天把 模态框&#xff08;Reveal&#xff09;讲得明明白白&#xff01;Foundation 6 中的 Reveal 是最强大的…

作者头像 李华
网站建设 2026/3/6 7:40:52

Vim光标移动效率革命:EasyMotion与Sneak终极对决

Vim光标移动效率革命&#xff1a;EasyMotion与Sneak终极对决 【免费下载链接】vim-galore :mortar_board: All things Vim! 项目地址: https://gitcode.com/gh_mirrors/vi/vim-galore 还在为Vim中缓慢的光标移动而苦恼&#xff1f;今天我们将深入对比两款改变游戏规则的…

作者头像 李华
网站建设 2026/3/4 23:23:40

游戏公司渲染软件管控:错峰使用遗传算法降采购成本

游戏公司渲染软件管控&#xff1a;错峰使用遗传算法降采购成本前言&#xff1a;成本节约不是选择题&#xff0c;是必答题在游戏行业竞争日益激烈的背景下&#xff0c;成本控制已经成为决定企业生存与发展的关键因素之一。是像渲染软件这类高性能、高投入的工具&#xff0c;对于…

作者头像 李华
网站建设 2026/3/5 14:37:39

19、多种操作系统在VMware中的使用指南

多种操作系统在VMware中的使用指南 1. Solaris系统相关 1.1 Solaris启动过程 Solaris Intel平台版通过两步启动。首先从DOS分区加载一个(DOS)配置助手。若以交互模式进入该助手(首次安装时会这样),可以从其他设备启动并探测新添加的硬件,也能扫描特定硬件,但要注意,…

作者头像 李华
网站建设 2026/3/9 10:15:27

PurestAdmin:新一代企业级RBAC权限管理框架的革新之路

PurestAdmin&#xff1a;新一代企业级RBAC权限管理框架的革新之路 【免费下载链接】purest-admin 基于 .NET 8 vue3 实现的极简rabc权限管理系统后端 后端基于精简后的abp框架&#xff0c;前端基于vue-pure-admin&#xff0c;前端极强的表格框架vxe-table&#xff0c;旨在打造…

作者头像 李华
网站建设 2026/3/5 8:41:41

软件许可优化如何破解企业资源闲置与成本失控难题?

软件许可优化如何破解企业资源闲置与成本失控难题&#xff1f;作为一家在IT服务领域深耕多年的企业&#xff0c;我深知企业在信息化建设过程中常常面临的两大顽疾——资源闲置和成本失控。是在当前竞争日益激烈、数字化转型加速的背景下&#xff0c;很多企业即使投入了大量资金…

作者头像 李华