2020-07-13所学(Java)

1.刷题

682. 棒球比赛 (Tag为栈)

思路:按照题意一步一步写即可,没有什么骚操作。

需掌握下面的知识点:

一、int转String有三种方式

(1)num + ""

(2)String.valueOf(num) 常用

(3)Integer.toString(num)

二、String转int有两种方式

(1)Integer.parseInt(str) 常用

(2)Integer.valueOf(str).intValue()

350. 两个数组的交集 II(Tag为数组,哈希)

猜到了哈希,但好多函数没用过

思路:遍历长数组,用哈希表存储元素及其出现的次数,构建哈希表。然后遍历短数组,有重复元素,就将哈希表中出现次数减一,并将重复元素存储到新数组中,当出现次数为0,就将元素从哈希表中删除

涉及到的一些函数:

Arrays.copyOfRange(T[ ] original,int from,int to)
将一个原始的数组original,从小标from开始复制,复制到小标to,生成一个新的数组。注意这里包括下标from,不包括下标to。

V getOrDefault(Object key,V defaultValue)

源码:

default V getOrDefault(Object key, V defaultValue) {
V v;
return (((v = get(key)) != null) || containsKey(key)) ? v : defaultValue;
}

当Map集合中有key时,就使用key值对应的value,如果没有就使用默认值defaultValue

1029. 两地调度(Tag为贪心)

很有意思的一道题,感觉就像小学数学奥赛题一样,哈哈,我没做出来

思路:贪心+排序。用去A城的开销减去 去B城的开销,得一数组,数组中小于0 的元素表示,去A的开销小于去B的开销,反之去B的开销小于去A的开销,排序(升序)。假设全部去A,得去A的总开销,但需要有一半人去B,而要保证最小,故需要找去B开销小的那一部分,即数组中大于0的数,总开销减去排在后面N / 2 个元素,得到的开销即为最小开销

涉及的知识点:

(1)Array.sort(int[ ] nums ),默认是升序排序

(2)数组名加上length(arr.length),表示该数组的行数(Row);

(3)指定索引加上length(arr[x].length),表示该行的元素个数,即该行的列数(Column)。

459. 重复的子字符串(Tag为字符串)

完全不知道咋写,看了下大佬的思路,瞬间跪下,直接附上大佬思路

思路:如果字符串S包含一个重复的子字符串,那么这意味着可以多次“移位和换行”字符串,并使其与原始字符串匹配

例如:abcabc
移位一次:cabcab
移位两次:bcabca
移位三次:abcabc

现在字符串和原字符串匹配了,所以可以得出结论存在重复的子串

基于这个思想,可以每次移动k个字符,直到匹配移动length - 1次。但是这样对于重复字符串很长的字符串,效率会非常低。在LeetCode中执行时间超时了。

为了避免这种无用的环绕,可以创建一个新的字符串str,它等于原来的字符串S再加上S自身,这样其实就包含了所有移动的字符串。

比如字符串:S = acd,那么str = S + S = acdacd

acd移动的可能:dac、cda。其实都包含在了str中了。就像一个滑动窗口

一开始acd (acd) ,移动一次ac(dac)d,移动两次a(cda)cd。循环结束

所以可以直接判断str中去除首尾元素之后,是否包含自身元素。如果包含。则表明存在重复子串。

作者:13217319563
链接:https://leetcode-cn.com/problems/repeated-substring-pattern/solution/jian-dan-ming-liao-guan-yu-javaliang-xing-dai-ma-s/
来源:力扣(LeetCode)

2.进程与线程(写个大纲)

(1)进程:一个进程就是一个正在执行的程序的实例。进程是资源分配的基本单位。每个进程占用一个进程控制块(PCB),PCB是进程存在的唯一标志。

(2)线程:线程是进程中的一条执行流程,是独立调度的基本单位。一个进程可以有多个线程,他们共享进程资源。

(3)进程与线程的区别

1.拥有资源方面:

进程是资源分配的基本单位,线程不拥有资源,但线程可以访问隶属进程的资源。

2.调度方面:

线程是独立调度的基本单位,在同一进程中,线程的切换不会引起进程的切换,而从一个进程中的线程切换到另一个进程中的线程,会引起进程的切换。

3.系统开销方面:

由于创建或撤销进程时,系统要为其分配或回收资源,所付出的开销远大于创建或撤销线程。进程切换时,涉及当前执行进程CPU环境的保存及新进程CPU环境的设置,而线程切换时只需保存和设置少量寄存器内容,开销小。

4.通信方面:

线程可直接读写同一进程中的数据进行通信,而进程通信需要借助IPC(进程间通信)

(4)IPC

1.概念:即进程间的信息交换

各个进程拥有的内存地址空间相互独立,为保证安全,一个进程不能直接访问另一个进程的地址空间。

2.通信方法

一.共享存储

二.管道通信

三.消息传递

四.信号量

五.Socket

(5)进程的七状态模型(掌握状态间的相互转化)

1.创建状态
2.就绪状态
3.就绪挂起状态
4.运行状态
5.阻塞状态
6.阻塞挂起状态
7.结束状态

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

推荐阅读更多精彩内容

  • 一、Java 基础 JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,j...
    程序男保姆阅读 161评论 0 0
  • Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java 技术具有卓越的通用性、高效性、平台移植性和...
    Java小辰阅读 400评论 1 3
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,523评论 16 22
  • 创业是很多人的梦想,多少人为了理想和不甘选择了创业来实现自我价值,我就是其中一个。 创业后,我由女人变成了超人,什...
    亦宝宝阅读 1,811评论 4 1
  • 今天感恩节哎,感谢一直在我身边的亲朋好友。感恩相遇!感恩不离不弃。 中午开了第一次的党会,身份的转变要...
    迷月闪星情阅读 10,566评论 0 11