Algorithm
Add Two Numbers(#2)
1 | /* |
这道题我们可以创建一个辅助节点pre 再用一个节点cur指向我们正在进行计算的结果链表上的节点。
通过对l1, l2这两条链做遍历,我们可以获得l1, l2 当前节点的值x 和 y,可以计算出他们与进位标识(变量carry,初始值为0)的和sum。可以通过对carry被10整除的余数来得知当前节点的两数相加是否进位。通过对sum的值对10取mod,可以得到加了进位后的值。
之后就是创建辅助节点链的后一个节点,并把cur指向新节点。如果这次运算有进位,则再新增一个值为carry的节点。 这样重复直到l1 或 l2到达链尾,如果不同时到达链尾,则结果链表依次把未到达链尾的数复制,最后l1,l2都到达链尾,计算结束。
Reading
Python at Netflix
https://medium.com/netflix-techblog/python-at-netflix-bba45dae649e
这篇文章主要介绍了Python在Netflix技术架构中的应用。给想要用Python搞事情的朋友们一些有事实支持的思路。
Tips
本周分享一下Java内存模型的happen before原则
- 程序次序规则:在一个线程内,按照程序代码顺序,书写在前面的操作happens before于书写在后面的操作。准确地说,应该是控制流顺序而不是程序代码顺序,因为要考虑分支、循环等结构。如果在一个线程的操作,那么前一个操作的结果必定对后续操作可见。
- 管程锁定规则:一个unlock操作happens before于后面对同一个锁的lock操作。这里必须强调的是同一个锁,而”后面”是指时间上的先后顺序。最常见的就是syncronized 方法和syncronized代码块。
- volatile变量规则:对一个volatile变量的写操作happens before于后面对这个变量的读操作,这里的”后面”同样是指时间上的先后顺序。该规则在ConcurrentHashMap 中读操作不需要加锁中有很好的体现。
- 线程启动规则:Thread对象的start()方法happens before于此线程的每一个动作。
- 线程终止规则:线程中的所有操作都先行发生于对此线程的终止检测,我们可以通过Thread.join()方法结束、Thread.isAlive()的返回值等手段检测到线程已经终止执行。
- 线程中断规则:对线程interrupt()方法的调用先行发生于被中断线程的代码检测到中断事件的发生,可以通过Thread.interrupted()方法检测到是否有中断发生。
- 对象终结规则:一个对象的初始化完成(构造函数执行结束)先行发生于它的finalize()方法的开始。
传递性:如果 A happens before B,且B happens before C,则A happens before C
Share
打造 Mac 下高颜值好用的终端环境
https://blog.biezhi.me/2018/11/build-a-beautiful-mac-terminal-environment.html