java 并发 收获

java 语句在执行过程中会执行指令重排序,保证多线程的不出错,那么需要保证程序在执行的过程中,有原子性,可见性,一致性。

摆动序列

https://leetcode-cn.com/problems/wiggle-sort-ii/

本想着在九十分钟冲刺一下做几道题,但是事实上还需要努力啊。
苦于最近做题的速度实在是太慢。

学到了一种分析方法,先从最简单的,暴力的想法一步步优化我们的代码。
主要是需要懂得分析比如对全部的数据进行排序,但是我们并不关心数据内部的情况。
所以不需要全部排序,只要拿出中间元素的数字就好了。

然后我们再次分析有相同元素的穿插问题。
这时候需要不断地排除尝试,然后得出应该对原来的数据进行逆序排序。
这时候再考虑如何优化空间的复杂度。

这道题的本质是找到中位数,然后进行划分:
这里可以查一下java 有无封装好的查找中位数的算法。

三分法可以在O(N)时间内将数组原地划分为严格小于中位数的数组,等于中位数的数组,严格大于中位数的数组。
这样在数组实现的过程中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值