登录
首页 >  文章 >  java教程

数组偶数位移计算技巧详解

时间:2026-03-21 19:18:43 253浏览 收藏

本文揭示了一种巧妙而高效的数组偶数位移计算方法:不进行任何实际元素移动,仅通过一次线性扫描,动态统计每个偶数左侧的奇数个数,即可精准得出其在“偶数前置、奇数后置”稳定重排中的位移量,时间复杂度O(n)、空间最优、逻辑直观且鲁棒性强;该思想不仅彻底规避了模拟交换带来的高开销与顺序错乱风险,更可自然扩展至各类稳定分区场景,堪称理解位移本质与写出工业级简洁代码的关键突破口。

如何计算数组中偶数元素在重排至前端时的位移量

本文介绍一种高效计算偶数元素位移量的方法:不实际移动数组,而是通过统计每个偶数前的奇数个数,直接得出其在重排后的位置偏移量,时间复杂度 O(n),空间最优且逻辑清晰。

本文介绍一种高效计算偶数元素位移量的方法:不实际移动数组,而是通过统计每个偶数前的奇数个数,直接得出其在重排后的位置偏移量,时间复杂度 O(n),空间最优且逻辑清晰。

在将数组中所有偶数“移动到前端、奇数移到后端”(保持偶数间与奇数间的相对顺序不变)的问题中,一个常见误区是试图模拟真实交换过程来追踪位移——这不仅代码复杂、易出错,而且时间复杂度高达 O(n²)。实际上,每个偶数的位移量, precisely 等于它在原数组中左侧出现的奇数个数

为什么?因为最终偶数序列紧邻排列在开头,且相对顺序不变;每个偶数只需“跳过”其前方所有奇数即可到达目标位置。例如:

int[] a = {1, 3, 2, 5, 4, 7, 8, 6};
// 索引:   0  1  2  3  4  5  6  7
// 奇偶:   奇 奇 偶 奇 偶 奇 偶 偶
// 左侧奇数个数:      2     3     4     4 → 即位移量 [2, 3, 4, 4]
  • 2(索引2)左侧有 1,3 → 2个奇数 → 位移量为 2
  • 4(索引4)左侧有 1,3,5 → 3个奇数 → 位移量为 3
  • 8(索引6)左侧有 1,3,5,7 → 4个奇数 → 位移量为 4
  • 6(索引7)左侧仍有 1,3,5,7 → 4个奇数 → 位移量为 4

因此,只需一次线性遍历,维护一个累计奇数计数器 oddCount,遇到偶数即记录当前 oddCount 值,遇到奇数则递增 oddCount。

✅ 推荐实现(使用 ArrayList 动态收集)

import java.util.*;

public class EvenShiftCalculator {
    public static int[] calculateEvenShifts(int[] arr) {
        List<Integer> shifts = new ArrayList<>();
        int oddCount = 0;

        for (int num : arr) {
            if (num % 2 == 0) {
                shifts.add(oddCount);
            } else {
                oddCount++;
            }
        }

        // 转为 int[] 数组(Java 8+)
        return shifts.stream().mapToInt(Integer::intValue).toArray();
    }

    // 测试示例
    public static void main(String[] args) {
        int[] a = {1, 3, 2, 5, 4, 7, 8, 6};
        int[] result = calculateEvenShifts(a);
        System.out.println(Arrays.toString(result)); // 输出: [2, 3, 4, 4]
    }
}

⚠️ 注意事项与优化建议

  • 无需修改原数组:本方法纯读取,零副作用,线程安全,符合函数式编程思想;
  • 空间可控:若已知偶数个数 evenCount(如预处理统计),可直接初始化 int[] shifts = new int[evenCount] 并用索引写入,避免 ArrayList 扩容开销;
  • 边界兼容:空数组、全奇数(返回空数组)、全偶数(返回全 0 数组)均自然支持;
  • 扩展性强:该思路可推广至任意“稳定分区”场景(如负数前置/正数后置),位移量 = 目标区域外的干扰元素数量;
  • 避免陷阱:原始代码中嵌套循环做冒泡式左移,既破坏稳定性(偶数间顺序可能错乱),又无法正确计算位移(因多次覆盖导致计数失真)。

综上,理解“位移本质是跨过干扰元素的数量”,是解决此类稳定重排位移问题的关键洞察。一次遍历、常数额外空间、语义清晰——这才是工业级代码应有的简洁与健壮。

本篇关于《数组偶数位移计算技巧详解》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>