ARTS Week 11
Jan 6, 2020 ~ Jan 12, 2020
Algorithm
Problem 108 Convert Sorted Array to Binary Search Tree (将有序数组转化为二叉搜索树) 题目链接
题目描述:给定一个有序数组,将其转换为一个高度平衡的二叉搜索树。高度平衡:对于树中任一结点,其左子树和右子树的高度不大于1。二叉搜索树:对于树中任一结点,其左子树所有结点的值小于等于该结点的值,其右子树所有结点的值大于等于该结点的值。例如给定数组为 [-10,-3,0,5,9],得到的高度平衡的二叉搜索树如下:
0
/ \
-3 9
/ /
-10 5
思路为:因为题目要求高度平衡,那么说明左右子树结点数目应该相近,同时要求是高度平衡和二叉搜索树都是递归的定义,且给定的是一个有序数组,不难想到使用递归。递归的初始条件便是:数组中没有元素或者只有一个元素,没有元素返回 None 即可,只有一个元素,则用该元素的值构建一个树结点即可。若多于一个元素,可以用 nums[len(nums)//2] 构建根节点,之后用 nums[0: len(nums)//2] 和 nums[len(nums)//2+1: len(nums)] 分别构建左右子树。
通过的代码如下
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def sortedArrayToBST(self, nums: List[int]) -> TreeNode:
if len(nums) == 0:
return None
if len(nums) == 1:
node = TreeNode(nums[0])
return node
node = TreeNode(nums[len(nums)//2])
node.left = self.sortedArrayToBST(nums[0: len(nums)//2])
node.right = self.sortedArrayToBST(nums[len(nums)//2+1: len(nums)])
return node
Review
本周继续 Review 每个程序员需要知道的97件事(英文名:97 Things Every Programmer Should Know)。原文链接。下面是本周的5个小内容:
- 区分业务异常和技术异常(Distinguish Business Exceptions from Technical) 原文链接
技术异常取决有编程语言本身,比如大多数语言在访问超出数组索引的元素时,会抛出一个异常来告诉你出现了错误。而业务异常是根据业务规则确定的,比如,银行账户只有100元,但想要取出200元时就会产生的一个异常。无论是技术异常还是业务异常我们都需要正确的处理它。 - 刻意练习(Do Lots of Deliberate Practice) 原文链接
刻意练习不只是单单执行任务,完成任务。而是有意识的练习一提高执行任务的能力。刻意练习意味着重复,多次重复一达到掌握的程度。刻意练习那些已经掌握的东西毫无意义,刻意练习应该去练习那些不擅长,不熟悉的东西。 - 领域特定语言(Domain-Specific Languages) 原文链接
每一个领域都有其特定的术语,用于描述该领域特有的事物。领域特定语言(DSL)一般分为内部和外部:内部DSL是通用编程语言编写而成的,内部DSL封装了现有的API,库和业务代码,并且对外部提供必要的接口。外部DSL是语言的文本或图形表达,其可以包括词法分析器,语法分析器等。其中将外部DSL采用XML、Json等格式也很常见。 - 不要害怕犯错误(Don't Be Afraid to Break Things) 原文链接
无论一个多么有经验的人都可能会犯错误,通过犯错误进而改正错误有助于提高自己。当然犯错误也可能会带来问题,比如受到批评、惩罚等,所以可能存在害怕出错的心理。在软件开发过程中,有一个比较好的减少错误的办法便是,一次只进行小量的改动,而立马进行测试,通过这样的小而快的迭代,可以避免犯下大的错误。 - 不要对你的临时数据不满意(Don't Be Cute with Your Test Data) 原文链接
在代码中编写任何文本时(无论是注释,日志,对话框还是测试数据),请始终问问自己,如果公开,它将如何显示。它将全面保存一些信息。
Tips
Python中字符串方法str.ljust(),str.rjust(),str.center(),str.strip(),str.lstrip(),str.rstrip()的功能分别如下:
- str.ljust() :填充字符串,让其左对齐。默认用空格填充
- str.rjust() :填充字符串,让其右对齐。默认用空格填充
- str.center():填充字符串,让其居中。默认用空格填充
- str.strip() :截掉字符串两边的指定字符,默认是空白字符集合
- str.lstrip():截掉字符串左边的指定字符,默认是空白字符集合
- str.rstrip():截掉字符串右边的指定字符,默认是空白字符集合
空白字符集合为:{ ' ', '\t', '\n', '\v', '\f', '\r' }
示例如下:
s0 = 'hello'
s11 = s0.ljust(10)
s12 = s0.ljust(10,'!')
s21 = s0.rjust(10)
s22 = s0.rjust(10,'!')
s31 = s0.center(10)
s32 = s0.center(10,'!')
print('s0 = ',s0)
print('s11 = ',s11)
print('s12 = ',s12)
print('s21 = ',s21)
print('s22 = ',s22)
print('s31 = ',s31)
print('s32 = ',s32)
print('s12.lstrip() = ',s12.lstrip('!'))
print('s12.rstrip() = ',s12.rstrip('!'))
print('s22.lstrip() = ',s22.lstrip('!'))
print('s22.rstrip() = ',s22.rstrip('!'))
print('s32.strip() = ',s32.strip('!'))
print('s32.strip() = ',s32.strip())
'''
输出结果如下:
s0 = hello
s11 = hello
s12 = hello!!!!!
s21 = hello
s22 = !!!!!hello
s31 = hello
s32 = !!hello!!!
s12.lstrip() = hello!!!!!
s12.rstrip() = hello
s22.lstrip() = hello
s22.rstrip() = !!!!!hello
s32.strip() = hello
s32.strip() = !!hello!!!
'''
Sharing
在 Review 部分中,提到技术异常和业务异常的区别,作为程序员,找到的技术异常比业务异常容易不少,但是业务异常同样值得关注,如果不慎就会带来巨大的损失。
ARTS Week 11的更多相关文章
- 地区sql
/*Navicat MySQL Data Transfer Source Server : localhostSource Server Version : 50136Source Host : lo ...
- ARTS 1.7 - 1.11
每周一个 Algorithm,Review 一篇英文文章,总结一个工作中的技术 Tip,以及 Share 一个传递价值观的东西! Algorithm: 学习算法 题目: https://leetcod ...
- arts打开第11周
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写. 说明:本题中,我们将空字符串定义为有效的回文串. 示例 1: 输入: "A man, a plan, a c ...
- 小白的python之路10/31&11/1文件操作系统
文件操作系统的介绍 ext4的superblock块是超级快,innode 块是专门存放文件信息的, block count将硬盘做成block块,对操作系统而言写在block块上就可了,eg:文件1 ...
- 【ARTS】01_18_左耳听风-20190311~20190317
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_08_左耳听风-20181231~20190106
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_06_左耳听风-20181217~1223
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 一切从这里起始(左耳听风 ARTS 6号小组 week 1)
ARTS 具体要求: 1.每周至少做一个 leetcode 的算法题2.阅读并点评至少一篇英文技术文章3.学习至少一个技术技巧4.分享一篇有观点和思考的技术文章 1.Algorithm Two Sum ...
- 【ARTS】01_44_左耳听风-201900909~201900915
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
随机推荐
- C语言关键字const作用及其应用
只要学过C语言的,都有知道const这个关键字,知道是用来定义常量的,如果一个变量被const修饰,那么它的值就不能再被改变,那么还有什么其他作用呢? 一.const常用作用 1.修饰局部变量 con ...
- floj 2265 【lxs Contest #141】航海舰队
首先抠出包围了阵形的最小矩形. 将地图拉伸成一条链,即将第一行.第二行.第三行按顺序连接.阵形也可以用同样的方法处理. 那么问题转化为,给定两个 01 串 S 和 T,问每个 S 中长度为 |T| 的 ...
- C#登出系统并清除Cookie
1.前端页面代码: 前端页面代码主要显示退出系统或者网站的可视化按钮代码,代码如下:(请忽略项目关键字:CPU) <ul class="nav navbar-nav navbar-ri ...
- js-xlsx 一个实用的js 导出列表插件
在前端开发过程中,导出列表功能的开发无非两种,一种是有后台生成,发生给前端下载,第二种是前端进行列表的导出工作.之前接触了一种前端导出列表的插件 tableExport.js ,但是其缺点很明显,需要 ...
- dp-最长递增子序列 (LIS)
首先引出一个例子 问题 : 给你一个长度为 6 的数组 , 数组元素为 { 1 ,4,5,6,2,3,8 } , 则其最长单调递增子序列为 { 1 , 4 , 5 , 6 , 8 } , 并且长度为 ...
- Ansible配合Virtualenv安装配置
Ansible的两种安装模式(Centos7) 1.Yum包管理安装 #yum -y install ansible 2.Git源代码安装[推荐] git clone https://github.c ...
- 10.方法重写Override
方法重写:Override: 需要有继承关系,子类重写父类的方法! 方法名必须相同 参数列表必须相同 修饰符:范围可以扩大,但不能缩小:public>protected>defalut&g ...
- jmeter使用—计数器的使用
说一下jmeter中,配置元件-计数器的使用. 如果需要引用的数据量较大,且要求不能重复或者需要自增,那么可以使用计数器来实现. 1.启动jmeter,添加线程组,右键添加配置元件——计数器,如下图: ...
- JavaWeb高级编程(上)
好久没更新了,发一篇以前记录学习的笔记. 面向读者:已经具有丰富的Java语言和Java SE平台知识的软件开发者和软件工程师. 预掌握知识: Internet.TCP.HTTP协议 HTML(5) ...
- mysql--->MySQL错误日志
MySQL错误日志 简介 MySQL错误日志是记录MySQL 运行过程中较为严重的警告和错误信息,以及MySQL每次启动和关闭的详细信息.错误日志的命名通常为hostname.err.其中,hostn ...