news 2026/4/16 15:52:19

卡牌游戏(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/16 12:27:05

如何用字节跳动开源AI助手让工作效率翻倍?

如何用字节跳动开源AI助手让工作效率翻倍&#xff1f; 【免费下载链接】UI-TARS-2B-SFT 项目地址: https://ai.gitcode.com/hf_mirrors/ByteDance-Seed/UI-TARS-2B-SFT 还在为重复的电脑操作烦恼吗&#xff1f;每天花费大量时间在Excel数据处理、邮件整理、文件归档上&…

作者头像 李华
网站建设 2026/4/11 22:35:17

智慧园区系统:技术赋能下的园区管理革新与价值升级

在数字经济加速渗透的今天&#xff0c;智慧园区系统已成为破解传统园区管理瓶颈、激活产业发展动能的核心支撑。它不再是简单的技术叠加&#xff0c;而是集数据整合、智能管控、服务优化于一体的综合性管理生态&#xff0c;通过融合大数据、物联网、云计算、人工智能等前沿技术…

作者头像 李华
网站建设 2026/4/16 14:32:09

OptiLayer V2025.11光学薄膜设计软件

1. 运算与生产适配性强&#xff1a;采用独特针式算法&#xff0c;运算速度比同类软件快数百倍&#xff0c;即便处理数十层复杂膜层&#xff0c;也能在不中断沉积过程的前提下完成参数测定与优化&#xff0c;还能降低生产成本、缩短生产周期。同时算法对生产和监测误差的稳定性大…

作者头像 李华
网站建设 2026/4/16 15:24:18

Apache Weex移动端渲染性能深度优化指南

在移动应用开发中&#xff0c;渲染性能直接影响用户体验&#xff0c;过度绘制问题往往成为性能瓶颈的重要因素。Apache Weex作为跨平台解决方案&#xff0c;其Native渲染引擎提供了系统化的优化手段来提升应用流畅度&#xff0c;减少资源消耗。本文将深入剖析渲染优化、性能提升…

作者头像 李华
网站建设 2026/4/10 21:47:55

攻克SLAM时间同步难题:Cartographer多传感器融合技术深度剖析

攻克SLAM时间同步难题&#xff1a;Cartographer多传感器融合技术深度剖析 【免费下载链接】cartographer Cartographer is a system that provides real-time simultaneous localization and mapping (SLAM) in 2D and 3D across multiple platforms and sensor configurations…

作者头像 李华
网站建设 2026/4/16 12:27:53

护网行动个人工作经验总结

网络安全实战宝典&#xff1a;护网行动经验总结&#xff0c;小白也能快速提升的安全技能&#xff08;建议收藏&#xff09; 文章详细记录了护网行动实战经验&#xff0c;涵盖防守、攻击和组织协调工作内容。强调资产梳理、漏洞修复、安全监测等关键环节&#xff0c;以及面临的…

作者头像 李华