您的位置:首页 >检测数组重复数字模式的方法
发布于2026-04-20 阅读(0)
扫一扫,手机访问

本文介绍如何在数组中自动识别连续、等长的重复数字子序列(如“142857”),提供可运行的 JavaScript 实现,支持自定义模式长度,并输出重复段的起始与结束索引。
本文介绍如何在数组中自动识别连续、等长的重复数字子序列(如“142857”),提供可运行的 JavaScript 实现,支持自定义模式长度,并输出重复段的起始与结束索引。
在处理数字序列(如小数展开、周期性数据或编码信号)时,识别重复的固定长度数字模式是一项常见需求。例如,1/7 = 0.142857142857… 的小数部分呈现经典循环节 142857;给定一个混合类型数组(含数字、字符串甚至分隔符),我们需要精准定位该模式首次重复出现的位置。
核心思路是:滑动窗口 + 哈希查重。我们设定目标模式长度(如 6),遍历数组所有可能的连续子序列(长度为 pattern_length),将其拼接为字符串并存入历史记录;一旦发现某子串已存在,则立即判定为重复模式,并返回其两次出现的索引区间。
以下是优化后的完整实现(修复原代码中 arr[j] || arr[j]===0 的逻辑缺陷,正确处理 0 和 '.' 等 falsy 值):
function findFirstRepetitivePattern(arr, patternLength = 6) {
if (arr.length < patternLength * 2) {
return { found: false, pattern: null, positions: [] };
}
const seen = new Map(); // 存储 pattern → 首次起始索引
const results = [];
for (let i = 0; i <= arr.length - patternLength; i++) {
// 安全拼接:显式转换为字符串,保留 0、'.' 等原始值
const segment = arr.slice(i, i + patternLength).map(String).join('');
if (seen.has(segment)) {
const firstIndex = seen.get(segment);
results.push({
pattern: segment,
first: { start: firstIndex, end: firstIndex + patternLength - 1 },
second: { start: i, end: i + patternLength - 1 }
});
break; // 找到首个重复即返回;如需全部,移除此 break
}
seen.set(segment, i);
}
return results.length > 0
? { found: true, ...results[0] }
: { found: false, pattern: null, positions: [] };
}
// 测试用例
const arr = [0, '.', 1, 4, 2, 8, 5, 7, 1, 4, 2, 8, 5, 7, 1, 4];
const result = findFirstRepetitivePattern(arr, 6);
if (result.found) {
console.log(`重复模式 "${result.pattern}" 发现于:`);
console.log(`第 1 次:索引 [${result.first.start}, ${result.first.end}]`);
console.log(`第 2 次:索引 [${result.second.start}, ${result.second.end}]`);
} else {
console.log('未找到指定长度的重复模式');
}✅ 关键改进说明:
⚠️ 注意事项:
通过此方法,你可快速定位周期性数字规律,为数据分析、密码学初筛或数学教学工具提供可靠基础。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9