【1】两数之和
class Solution:
def twoSum(self, nums: List[int], target: int) -> List[int]:
for i in range(len(nums)):
for j in range(len(nums)):
if(i==j):
continue
if(nums[i]+nums[j]==target):
return [i,j]
return []
【2】两数相加
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:
l3 = ListNode(0)
l3_tmp = l3;
pre_get = 0;
while(l1 or l2):
l1_val = l1.val if l1 else 0;
l2_val = l2.val if l2 else 0;
cur_res = (l1_val+l2_val+pre_get)%10;
pre_get = (l1_val+l2_val+pre_get)//10;
l3_tmp.next = ListNode(cur_res);
l3_tmp = l3_tmp.next
if l1 is not None:
l1 = l1.next;
if l2 is not None:
l2 = l2.next;
if(pre_get>0):
l3_tmp.next = ListNode(1);
return l3.next;