news 2026/4/23 14:07:16

(新卷,100分)- 喊7的次数重排(Java JS Python)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,100分)- 喊7的次数重排(Java JS Python)

(新卷,100分)- 喊7的次数重排(Java & JS & Python)

题目描述

喊7是一个传统的聚会游戏,N个人围成一圈,按顺时针从1到N编号。

编号为1的人从1开始喊数,下一个人喊的数字为上一个人的数字加1,但是当将要喊出来的数字是7的倍数或者数字本身含有7的话,不能把这个数字直接喊出来,而是要喊”过”。

假定玩这个游戏的N个人都没有失误地在正确的时机喊了”过”,当喊到数字K时,可以统计每个人喊”过”的次数。

现给定一个长度为N的数组,存储了打乱顺序的每个人喊”过”的次数,请把它还原成正确的顺序,即数组的第i个元素存储编号i的人喊”过”的次数。

输入描述

输入为一行,为空格分隔的喊”过”的次数,注意K并不提供,K不超过200,而数字的个数即为N。

输出描述

输出为一行,为顺序正确的喊”过”的次数,也由空格分隔。

用例
输入0 1 0
输出1 0 0
说明

一共只有一次喊”过”,那只会发生在需要喊7时,按顺序,编号为1的人会遇到7,故输出1 0 0。

注意

结束时的K不一定是7,也可以是8、9等,喊过的次数都是1 0 0。

输入0 0 0 2 1
输出0 2 0 1 0
说明一共有三次喊”过”,发生在7 14 17,按顺序,编号为2的人会遇到7 17,编号为4的人会遇到14,故输出0 2 0 1 0。
题目解析

本题是约瑟夫环问题,有多种解法

本题采用环形数组解法,所谓环形数组,即数组的尾部元素的下一个是数组头部元素

Java算法源码
import java.util.Arrays; import java.util.Scanner; import java.util.StringJoiner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); Integer[] arr = Arrays.stream(sc.nextLine().split(" ")).map(Integer::parseInt).toArray(Integer[]::new); System.out.println(getResult(arr)); } public static String getResult(Integer[] arr) { // totalGo表示一共喊了多少次过 int totalGo = Arrays.stream(arr).reduce(Integer::sum).orElse(0); // n表示一共几个人 int n = arr.length; // p[i]表示每个人喊了几次过,初始为0 int[] p = new int[n]; // go保存含有7的数字,或者是7倍数的数字 int i = 1; int j = 0; while (totalGo > 0) { if (i % 7 == 0 || (i + "").contains("7")) { totalGo--; p[j]++; } i++; j++; if (j >= n) j = 0; } StringJoiner sj = new StringJoiner(" "); for (int v : p) { sj.add(v + ""); } return sj.toString(); } }
JS算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { const arr = line.split(" ").map(Number); // n表示一共几个人 const n = arr.length; // p数组统计每个人喊过的次数 const p = new Array(n).fill(0); // totalGo表示一共喊了多少次过 let totalGo = arr.reduce((p, c) => p + c); // 每遇7喊过,比如7,14,17,21,27,28,35,37,42,即数字含有7,或者数字是7的倍数 let i = 1; let j = 0; while (totalGo) { if (i % 7 === 0 || String(i).indexOf(7) !== -1) { totalGo--; p[j]++; } i++; j++; if (j >= n) { j = 0; } } console.log(p.join(" ")); });
Python算法源码
# 输入获取 arr = list(map(int, input().split())) # 算法入口 def getResult(): # totalGo表示一共喊了多少次过 totalGo = sum(arr) # n表示一共几个人 n = len(arr) # p[i]表示每个人喊了几次过,初始为0 p = [0]*n i = 1 j = 0 while totalGo > 0: if i % 7 == 0 or str(i).find("7") != -1: totalGo -= 1 p[j] += 1 i += 1 j += 1 if j >= n: j = 0 return " ".join(map(str, p)) # 算法调用 print(getResult())
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 10:24:29

连锁火锅智慧餐饮管理系统python后台-计算机毕业设计源码+LW文档

一、选题意义 随着信息技术的快速发展和餐饮行业竞争的加剧,传统的餐饮管理方式已难以满足连锁火锅企业的需求。智慧餐饮管理系统能够利用现代互联网、物联网等技术手段对火锅企业的各个运营环节进行高效管理。这有助于提高连锁火锅企业的运营效率,减少人…

作者头像 李华
网站建设 2026/4/19 8:26:58

【课程设计/毕业设计】基于Web的网上购物商城的设计与实现基于SpringBoot的网上购物商城设计与实现【附源码、数据库、万字文档】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/4/22 21:00:14

【数据库】【MySQL】事务隔离深度解析:MVCC 实现与幻读解决机制

MySQL 事务隔离深度解析:MVCC 实现与幻读解决机制 MySQL InnoDB 引擎通过 MVCC(多版本并发控制) 与 Next-Key Lock 的精密组合,在保障事务隔离性的同时实现了高性能并发。本文将深入剖析其实现原理与演进机制。一、事务隔离级别与…

作者头像 李华
网站建设 2026/4/18 6:32:22

智能降重有妙招:8款AI工具提升论文查重效率

学术写作中,查重率是衡量研究规范性的重要指标,但过高的重复率常给作者带来修改负担。为平衡学术严谨性与文本原创性,现代自然语言处理技术驱动的智能工具应运而生,它们能在保留核心语义的前提下对文本进行深度重构,显…

作者头像 李华
网站建设 2026/4/13 6:35:49

学霸同款2026 AI论文软件TOP9:MBA开题报告神器测评

学霸同款2026 AI论文软件TOP9:MBA开题报告神器测评 2026年MBA论文写作工具测评:精准筛选,高效助力开题 随着AI技术在学术领域的广泛应用,越来越多的MBA学生开始依赖智能写作工具提升论文效率。然而,面对市场上琳琅满目…

作者头像 李华
网站建设 2026/4/23 12:36:54

Java毕设项目:基于vue的社区生鲜团购在线管理平台基于SpribgBoot的生鲜团购平台(源码+文档,讲解、调试运行,定制等)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华