Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Damon-Da
leetcode
提交
b687629c
L
leetcode
项目概览
Damon-Da
/
leetcode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
leetcode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
b687629c
编写于
1月 30, 2019
作者:
L
liu13
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
20190130
上级
f7fb3a41
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
75 addition
and
2 deletion
+75
-2
code/lc118.java
code/lc118.java
+26
-2
code/lc125.java
code/lc125.java
+44
-0
code/lc5.java
code/lc5.java
+1
-0
readme.md
readme.md
+4
-0
未找到文件。
code/lc118.java
浏览文件 @
b687629c
package
code
;
/*
* 118. Pascal's Triangle
* 题意:上层元素相邻的和,两边补1,得到下层元素
* 难度:Easy
* 分类:Array
* 思路:迭代计算
* Tips:
*/
import
java.util.ArrayList
;
import
java.util.List
;
public
class
lc118
{
public
List
<
List
<
Integer
>>
generate
(
int
numRows
)
{
List
<
List
<
Integer
>>
res
=
new
ArrayList
<>();
if
(
numRows
==
0
)
return
res
;
List
<
Integer
>
ls
=
new
ArrayList
();
ls
.
add
(
1
);
//第一层1个1
res
.
add
(
ls
);
numRows
--;
if
(
numRows
==
0
)
return
res
;
while
(
numRows
>
0
){
ArrayList
<
Integer
>
temp
=
new
ArrayList
();
temp
.
add
(
1
);
for
(
int
i
=
0
;
i
<
ls
.
size
()-
1
;
i
++)
{
temp
.
add
(
ls
.
get
(
i
)+
ls
.
get
(
i
+
1
));
}
temp
.
add
(
1
);
res
.
add
(
temp
);
ls
=
temp
;
numRows
--;
}
return
res
;
}
}
code/lc125.java
0 → 100644
浏览文件 @
b687629c
package
code
;
/*
* 125. Valid Palindrome
* 题意:判断是否为回文
* 难度:Easy
* 分类:Two Pointers, String
* 思路:两个指针。另一种是正则表达式替换数字,字母为空格,再反转,判断是否相等。
* Tips:记下另一种方法。第一种方法Bingo!
* lc234, lc5
*/
public
class
lc125
{
public
static
void
main
(
String
[]
args
)
{
System
.
out
.
println
(
isPalindrome
(
"A man, a plan, a canal: Panama"
));
}
public
static
boolean
isPalindrome
(
String
s
)
{
int
begin
=
0
;
int
end
=
s
.
length
()-
1
;
s
=
s
.
toLowerCase
();
//转为小写
while
(
begin
<
end
&&
!(
helper
(
s
.
charAt
(
begin
))))
begin
++;
while
(
begin
<
end
&&
!(
helper
(
s
.
charAt
(
end
))))
end
--;
while
(
begin
<
end
){
if
(
s
.
charAt
(
begin
)==
s
.
charAt
(
end
)){
begin
++;
end
--;
while
(
begin
<
end
&&
!(
helper
(
s
.
charAt
(
begin
))))
begin
++;
while
(
begin
<
end
&&
!(
helper
(
s
.
charAt
(
end
))))
end
--;
}
else
{
return
false
;
}
}
return
true
;
}
public
static
boolean
helper
(
Character
ch
){
//过滤非字符数字
if
(
Character
.
isAlphabetic
(
ch
)||
Character
.
isDigit
(
ch
))
return
true
;
return
false
;
}
public
boolean
isPalindrome2
(
String
s
)
{
String
actual
=
s
.
replaceAll
(
"[^A-Za-z0-9]"
,
""
).
toLowerCase
();
String
rev
=
new
StringBuffer
(
actual
).
reverse
().
toString
();
return
actual
.
equals
(
rev
);
}
}
code/lc5.java
浏览文件 @
b687629c
...
...
@@ -5,6 +5,7 @@ package code;
* 难度:Medium
* 分类:String, Dynamic Programming
* Tips:从后往前遍历,保证后续dp时,子情况已计算出
* 还有一种思路是从中间往两边扩展,中间有两种情况,一种一个字符,一种两个字符
*/
public
class
lc5
{
public
static
void
main
(
String
[]
args
)
{
...
...
readme.md
浏览文件 @
b687629c
...
...
@@ -75,13 +75,17 @@ Language: Java
| 098
[
Java
](
./code/lc98.java
)
| 101
[
Java
](
./code/lc101.java
)
| 102
[
Java
](
./code/lc102.java
)
| 103
[
Java
](
./code/lc103.java
)
| 104
[
Java
](
./code/lc104.java
)
| 105
[
Java
](
./code/lc105.java
)
| 108
[
Java
](
./code/lc108.java
)
| 114
[
Java
](
./code/lc114.java
)
| 114
[
Java
](
./code/lc116.java
)
| 114
[
Java
](
./code/lc118.java
)
| 121
[
Java
](
./code/lc121.java
)
| 122
[
Java
](
./code/lc122.java
)
| 124
[
Java
](
./code/lc124.java
)
| 125
[
Java
](
./code/lc125.java
)
| 128
[
Java
](
./code/lc128.java
)
| 136
[
Java
](
./code/lc136.java
)
| 139
[
Java
](
./code/lc139.java
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录