Valid Sudoku

  • 数独整体能够满足的情况是比较复杂.参考:编程之美 关于数独问题的讨论
  • 这道题的解法可能简单一点,因为对输入进行来限制.只是去判断是否是一个数独
    数独的形式相比较来说也是较简单的
  • 对于输入的复合列表,列表中的元素相对较稀疏,没有出现的数字用字符"."来代替
  • python 的zip()函数 a=list[list[]]
    for row in a 可以读取a 的行元素
    for col in zip(a)可以读取a的列元素
    zip(
    list[list[]]) 实现和矩阵一样的转置功能,不过目标是一个列表.
    还有zip生成的一个类是迭代器的,使用.next()来返回一个元组tuple()
  • python 的set()函数 会返回一个一个无重复元素的set的元素.
  • 注意区分python中的range方法,和元素枚举方法的差别
    例如:for i in range(0,3,6) 和 for i in(0,3,6)是完全两种概念.
  • C++中注意在for()中 ++i 与 i++的区别.i++先引用再自增;++i 是先自增再引用.在for 循环中可能还区别不大,但是在while()判断语句对最后的计算结果有很大的影响.

String to Integer(atoi)

  • 正则表达式:
    用来处理字符串的方法
    正则表达式是一种"表示法"
    ""一般是跟在需要重复元素的后面 
    转义序列:"",".","|","
    " 这些都是元字符,利用这些将元字符和字母表中的字符区别开来.
    注意反选和制表的差别,反选:[^a-z]; 制表'[1]',表示定位在行首的意义.
  • 表达式中的group函数,用来提取分组截获的字符串
  • 如果字符串中全是数字,则只要一个int(string),就可以将字符串转换成数字int .

Count and Say

  • 刚开始题目的理解有点问题.循环递减的大方向没有错.我认为是两个字符串的变换,但是别人代码中的循环递归看似简单,实则非常难.对于temp的交换,只是止步于能看懂 但是自己却是写不出来的.
  • 存在的小问题是python 及C++等语言的基础结构不了解,例如字符串如何表示,如何计数和表示字符串中的子字符串.
  • 自己的代码还有改进空间,这个思路方向再试试 count and say
  • 在python中 str()- is a keyword是程序内置的关键字.例如str(12)=='12'

Longest Word (lintcode)

  • 知识点:
    1.python中字符串也是可以实现 str.pop()操作
    2.C++中,对于vector ans {}; 整个vector可以进行 ans.size()

    对于其中的每个元素也可以实现 ans[i].size()
  • 实现方法有两种,分别是遍历一次和遍历两次

implemet strStr()

  • 注意的是,利用两次循环0(n^2)来实现的话,注意空字符串的判断
  • 采用暴力的模式匹配也可以
  • 最好的是采用 KMP算法。(这个算法还不是很理解)特别是next array 和nextval 在代码中的实现

sort letter by case

  • 需要注意的是,字符串利用循环要时刻检测循环数是否 out of range
  • 能不用一些像 erase isupper 函数 就尽量不用。 自己实现???

compare strings

  • python 字符的ascii 码 要利用 ord('a')=101
  • python 中没有自增 ++ 取而代之的是 +=1 ,这个很容易出错。

Longest Common Prefix

  • 解题思路:
    1.找到字符串中最短的子字符串,并保存长度
    2.随机抽取一个子字符串从头开始和所有的子字符串进行比对,所有子字符串都有的字符 进行保存
  • python 有个好用的set集合,循环最小长度,添加所有子字符串的i,set集合以后,如果大于两个元素,则元素不是common的 比较好用

convert sorted array to high balance binary tree

  • 这一题的 divide and conquer 的思想很重要
  • 与树的问题都会与递归有联系

binary tree inorder traversal

121 Best time to buy and sell stock

  • 找到数组中连续的差值最大化
"""
Say you have an array for which the ith element is the price of a given stock on day i.
If you were only permitted to complete at most one transaction (i.e., buy one and sell one share of the stock), design an algorithm to find the maximum profit.
Note that you cannot sell a stock before you buy one.
"""

Example1

Input: [7,1,5,3,6,4]
Output: 5
Explanation: Buy on day 2 (price = 1) and sell on day 5 (price = 6), profit = 6-1 = 5.
Not 7-1 = 6, as selling price needs to be larger than buying price.

Example 2

Input: [7,6,4,3,1]
Output: 0
Explanation: In this case, no transaction is done, i.e. max profit = 0.
import sys
class Solution:
def maxProfit(self, prices):
"""
:type prices: List[int]
:rtype: int
"""
# need robust
profit=0
min_price=sys.maxsize # 最小值的初始化,初始化为int的最大值
for i in prices:
if i<min_price:
min_price=i # 找到当前数值最小的价格
while i-min_price>profit:
profit=i-min_price #profit 用来保存每个数值与当前最小值的差值
return profit

  1. a-z ↩︎

LeetCode 笔记的更多相关文章

  1. Leetcode 笔记 113 - Path Sum II

    题目链接:Path Sum II | LeetCode OJ Given a binary tree and a sum, find all root-to-leaf paths where each ...

  2. Leetcode 笔记 112 - Path Sum

    题目链接:Path Sum | LeetCode OJ Given a binary tree and a sum, determine if the tree has a root-to-leaf ...

  3. Leetcode 笔记 110 - Balanced Binary Tree

    题目链接:Balanced Binary Tree | LeetCode OJ Given a binary tree, determine if it is height-balanced. For ...

  4. Leetcode 笔记 100 - Same Tree

    题目链接:Same Tree | LeetCode OJ Given two binary trees, write a function to check if they are equal or ...

  5. Leetcode 笔记 99 - Recover Binary Search Tree

    题目链接:Recover Binary Search Tree | LeetCode OJ Two elements of a binary search tree (BST) are swapped ...

  6. Leetcode 笔记 98 - Validate Binary Search Tree

    题目链接:Validate Binary Search Tree | LeetCode OJ Given a binary tree, determine if it is a valid binar ...

  7. Leetcode 笔记 101 - Symmetric Tree

    题目链接:Symmetric Tree | LeetCode OJ Given a binary tree, check whether it is a mirror of itself (ie, s ...

  8. Leetcode 笔记 36 - Sudoku Solver

    题目链接:Sudoku Solver | LeetCode OJ Write a program to solve a Sudoku puzzle by filling the empty cells ...

  9. Leetcode 笔记 35 - Valid Soduko

    题目链接:Valid Sudoku | LeetCode OJ Determine if a Sudoku is valid, according to: Sudoku Puzzles - The R ...

  10. Leetcode 笔记 117 - Populating Next Right Pointers in Each Node II

    题目链接:Populating Next Right Pointers in Each Node II | LeetCode OJ Follow up for problem "Popula ...

随机推荐

  1. 四、Python基础(1)

    目录 四.Python基础(1) 四.Python基础(1) 1.什么是变量? 一种变化的量,量是记录世界上的状态,变指得是这些状态是会变化的. 2.为什么有变量? 因为计算机程序的运行就是一系列状态 ...

  2. 爬虫获取搜狐汽车的配置信息 和swf动态图表的销量数据-------详细教学

    前情提要:需要爬取搜狐汽车的所有配置信息,具体配置对应的参数. 以及在动态图表上的历史销量. 比如: 一汽奥迪旗下Q5L 的<40 TFSI 荣享进取型 国VI >的历史销量和该配置的参数 ...

  3. Linux打开网易云的问题

    网易云需要ROOT权限启动,期间终端不能关闭退出,否则网易云音乐会自动退出.    终端输入:sudo netease-cloud-music &u

  4. Java Grammer:数据类型

    Java的数据类型 我们知道,Java是一种强类型语言,类型对于Java语言来说非常的重要不言而喻,在Java中,分为基础数据类型和引用数据类型,其中基础数据类型分为了四类八种: 下面,我们来分别说一 ...

  5. LeetCode刷题总结之双指针法

    Leetcode刷题总结 目前已经刷了50道题,从零开始刷题学到了很多精妙的解法和深刻的思想,因此想按方法对写过的题做一个总结 双指针法 双指针法有时也叫快慢指针,在数组里是用两个整型值代表下标,在链 ...

  6. java的八种数据类型

    1)四种整数类型(byte.short.int.long):    byte:8 位,用于表示最小数据单位,如文件中数据,-128~127    short:16 位,很少用,-32768 ~ 327 ...

  7. Streaming+Sparksql使用sql实时分析 rabbitmq+mongodb+hive

    SparkConf sparkConf = new SparkConf()//此处使用一个链接切记使用一个链接否则汇报有多个sparkcontext错误 .setAppName("Spark ...

  8. 算法与数据结构基础 - 分治法(Divide and Conquer)

    分治法基础 分治法(Divide and Conquer)顾名思义,思想核心是将问题拆分为子问题,对子问题求解.最终合并结果,分治法用伪代码表示如下: function f(input x size ...

  9. 8.9 day30 并发编程 进程理论 进程方法 守护进程 互斥锁

    多道技术 1.空间上的复用 多个程序共用一套计算机硬件 多道技术原理 2.时间上的复用 ​ 切换+保存状态 ​ 1.当一个程序遇到IO操作 操作系统会剥夺该程序的CPU执行权限( 提高了CPU的利用率 ...

  10. 【I'm Telling the Truth】【HDU - 3729】 【匈牙利算法,DFS】

    思路 题意:该题主要说几个同学分别说出自己的名次所处区间,最后输出可能存在的未说谎的人数及对应的学生编号,而且要求字典序最大. 思路:刚刚接触匈牙利算法,了解的还不太清楚,附一个专门讲解匈牙利算法的博 ...