ARTS Week 04

Algorithm

题目

922. 按奇偶排序数组 II

给定一个非负整数数组 A, A 中一半整数是奇数,一半整数是偶数。
对数组进行排序,以便当 A[i] 为奇数时,i 也是奇数;当 A[i] 为偶数时, i 也是偶数。
你可以返回任何满足上述条件的数组作为答案。
示例:
输入:[4,2,5,7]
输出:[4,5,2,7]
解释:[4,7,2,5],[2,5,4,7],[2,7,4,5] 也会被接受。

思路

1

循环遍历数组,每次迭代有三种可能的情况:
1.元素位置正确
2.奇数元素在偶数位置上
3.偶数元素在奇数位置上
这里需要对2、3两种情况进行处理,其思路如下:

  • 用一个队列存放异常的奇数位置下标,另一个队列存放异常的偶数位置下标。
  • 假设当前迭代是奇数在偶数位置上,需要先判断奇数队列是否有值,如果有的话,就取出队头元素,将当前元素和其交换。如果队列为空,则将当前元素加入偶数队列,以便下一次对偶数元素放错位置进行处理。

2

因为第一种思路实现的代码,而且有两段相似的代码,虽然能够实现,但是肯定还不够完美,因此这里参考了别人的思路,发现这种思路不仅代码简洁明了,而且效率有了很大幅度的提升。
循环遍历偶数位置的元素,如果发现当前元素为奇数,再循环遍历奇数位置的元素,知道在奇数位置发现了一个偶数,此时将当前的奇数位置和偶数位置的元素交换,如此操作,直至遍历完所有的偶数位置元素。

代码

1

    public int[] sortArrayByParityII(int[] arr) {
        if (arr == null) {
            return null;
        }

        Queue<Integer> evenIndexQueue = new LinkedList<>();
        Queue<Integer> oddIndexQueue = new LinkedList<>();

        for (int i = 0; i < arr.length; i++) {
            if (arr[i] % 2 != 0 && i % 2 == 0) {
                //奇数在偶数位
                if (oddIndexQueue.peek() != null) {
                    int oddIndex = oddIndexQueue.poll();

                    int tmp = arr[i];
                    arr[i] = arr[oddIndex];
                    arr[oddIndex] = tmp;
                } else {
                    evenIndexQueue.add(i);
                }
            } else if (arr[i] % 2 == 0 && i % 2 != 0) {
                //偶数在奇数位
                if (evenIndexQueue.peek() != null) {
                    int evenIndex = evenIndexQueue.poll();

                    int tmp = arr[i];
                    arr[i] = arr[evenIndex];
                    arr[evenIndex] = tmp;
                } else {
                    oddIndexQueue.add(i);
                }
            }
        }

        return arr;
    }

2

    public int[] sortArrayByParityII(int[] arr) {
        if (arr == null) {
            return null;
        }

        for (int i = 0, j = 1; i < arr.length; i += 2) {
            if ((arr[i] & 1) != 0) {
                while ((arr[j] & 1) != 0) {
                    j += 2;
                }

                int tmp = arr[i];
                arr[i] = arr[j];
                arr[j] = tmp;
            }
        }

        return arr;
    }

Review

这周从耗子叔的程序员练级攻略里发现了两篇文章让我感悟颇多:

Teach Yourself Programming in Ten Years
The Greatest Developer Fallacy Or The Wisest Words You’ll Ever Hear?

第一篇写了现在大家学习时只求速成的学习心态,并且分析了这种学习心态的不利影响。然后说明了无论哪个领域都需要花费十年甚至更久的时间来学习和积累,那样才能有所成就的,并且给出了自己对于编程的一些经验。

第二篇就程序员的至理名言“用到的时候再学”进行分析,全文都表达了对这个观点的反对,有理有据的进行分析,最终说明我们应该在一些领域深入学习和积累,最终的知识广度肯定会有很大的提升。

毕业之后,因为知道自己还欠缺算法、网络、操作系统等各方面知识,所以也有意识去学习。但却抱着快速掌握的心态去学,觉得这些暂时都用不上,等真正用到再深入学,结果导致任何一门都只是有个大概的了解,现在已经全都忘了。虽然之前也隐隐觉得这种学习心态好像不太对,但是也没有做一个深入的思考。读了这两篇文章之后幡然醒悟,发现必须要去除这种想要走捷径的心态,无论做什么都没有捷径可走,唯有一步一个脚印的去做,这样才能真正的学到一些有用的东西。

Tip

android dumpsys命令
1
获取当前 Android 系统 Activity 栈中 Activity 信息

adb shell dumpsys activity

等价于依次输入下面 8 条命令:

adb shell dumpsys activity intents //主要输出 PendingIntentRecord
adb shell dumpsys activity broadcasts 
adb shell dumpsys activity providers// Published single-user content providers (by class) / Published user 0 content providers (by class) /
adb shell dumpsys activity permissions
adb shell dumpsys activity services
adb shell dumpsys activity recents
adb shell dumpsys activity activities
adb shell dumpsys activity processes

2
获取当前 Android 系统 中与用户交互的 Activity 的详细信息

adb shell dumpsys activity top

3
显示当前所有在运行的任务栈,并可查看栈中所有的 Activity 的列表

adb shell dumpsys activity activities

4
获取手机里面某个 apk 的应用信息、版本信息

adb shell dumpsys package [应用包名]

5
查看应用的内存使用情况

adb shell dumpsys meminfo  [应用包名]

Share

https://www.jianshu.com/p/c4897ad61dc7

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容