Skip to content
Navigation Menu
Toggle navigation
Sign in
Product
GitHub Copilot
Write better code with AI
GitHub Advanced Security
Find and fix vulnerabilities
Actions
Automate any workflow
Codespaces
Instant dev environments
Issues
Plan and track work
Code Review
Manage code changes
Discussions
Collaborate outside of code
Code Search
Find more, search less
Explore
Why GitHub
All features
Documentation
GitHub Skills
Blog
Solutions
By company size
Enterprises
Small and medium teams
Startups
Nonprofits
By use case
DevSecOps
DevOps
CI/CD
View all use cases
By industry
Healthcare
Financial services
Manufacturing
Government
View all industries
View all solutions
Resources
Topics
AI
DevOps
Security
Software Development
View all
Explore
Learning Pathways
Events & Webinars
Ebooks & Whitepapers
Customer Stories
Partners
Executive Insights
Open Source
GitHub Sponsors
Fund open source developers
The ReadME Project
GitHub community articles
Repositories
Topics
Trending
Collections
Enterprise
Enterprise platform
AI-powered developer platform
Available add-ons
GitHub Advanced Security
Enterprise-grade security features
Copilot for business
Enterprise-grade AI features
Premium Support
Enterprise-grade 24/7 support
Pricing
Search or jump to...
Search code, repositories, users, issues, pull requests...
Search syntax tips
Provide feedback
Saved searches
Use saved searches to filter your results more quickly
Sign in
Sign up
Reseting focus
You signed in with another tab or window.
Reload
to refresh your session.
You signed out in another tab or window.
Reload
to refresh your session.
You switched accounts on another tab or window.
Reload
to refresh your session.
Dismiss alert
{{ message }}
beyondyyh
/
Leetcode
Public
Notifications
You must be signed in to change notification settings
Fork
1
Star
13
Code
Issues
0
Pull requests
0
Actions
Projects
0
Security
Insights
Additional navigation options
Code
Issues
Pull requests
Actions
Projects
Security
Insights
Files
master
Breadcrumbs
Leetcode
/
algorithms
/
linkedList
/
2.addTwoNumbers.go
Copy path
Blame
Blame
Latest commit
History
History
48 lines (45 loc) · 1.21 KB
master
Breadcrumbs
Leetcode
/
algorithms
/
linkedList
/
2.addTwoNumbers.go
Top
File metadata and controls
Code
Blame
48 lines (45 loc) · 1.21 KB
Raw
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package
linkedList
// 给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
//
// 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
//
// 您可以假设除了数字 0 之外,这两个数都不会以 0 开头。
//
// 示例:
//
// 输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
// 输出:7 -> 0 -> 8
// 原因:342 + 465 = 807
func
addTwoNumbers
(
l1
,
l2
*
ListNode
)
*
ListNode
{
var
head
*
ListNode
=
&
ListNode
{
Val
:
0
}
cur
:=
head
var
carry
int
for
l1
!=
nil
||
l2
!=
nil
{
// 踩坑:变量作用域的问题,xy一定不能再for外面���明,否则,
// 如果len(*l2) < len(*l1)时,y值异常,本来应该是0,但是保留了上一个位置的数
var
x
,
y
,
sum
int
if
l1
!=
nil
{
x
=
l1
.
Val
}
if
l2
!=
nil
{
y
=
l2
.
Val
}
sum
=
x
+
y
+
carry
carry
=
sum
/
10
sum
=
sum
%
10
// cur 循环
cur
.
Next
=
&
ListNode
{
Val
:
sum
}
cur
=
cur
.
Next
if
l1
!=
nil
{
l1
=
l1
.
Next
}
if
l2
!=
nil
{
l2
=
l2
.
Next
}
}
// 最后一位
if
carry
>
0
{
cur
.
Next
=
&
ListNode
{
Val
:
carry
}
}
return
head
.
Next
}
You can’t perform that action at this time.