LeetCode初级算法的Python实现--数组

# -*- coding: utf-8 -*-
"""
@Created on 2018/6/3 17:06 @author: ZhifengFang
""" # 排列数组删除重复项
def removeDuplicates(nums):
if len(nums) <= 1:
return len(nums)
i = 1
while len(nums) != i:
if nums[i] == nums[i - 1]:
del nums[i]
i -= 1
i += 1
return len(nums) # 买卖股票最佳时机2
def maxProfit(prices):
max = 0
if len(prices) <= 1:
return 0
for i in range(len(prices) - 1):
if prices[i] < prices[i + 1]:
max += prices[i + 1] - prices[i]
return max # 旋转数组
def rotate(nums, k):
# nums = nums[-k:] + nums[:k + 1]
# print(nums)
if len(nums) > 1:
k = k % len(nums)
if k != 0:
temp = nums[-k:]
nums[k:] = nums[:len(nums) - k]
nums[0:k] = temp
print(nums) # 判断数组中是否有重复元素
def containsDuplicate(nums):
# if len(nums)>len(set(nums)):
# return True
# return False
for num in nums:
if nums.count(num) > 1:
return True
return False # 获得里面只出现一次的数字
def singleNumber(nums):
numCounts = {}
result = []
for num in nums:
numCounts[num] = numCounts.get(num, 0) + 1
for key in numCounts.keys():
if numCounts.get(key) == 1:
result.append(key)
break
return result[0] # 两个数组的交集 II
def intersect(nums1, nums2):
if len(nums2) < len(nums1):
nums1, nums2 = nums2, nums1
newNums = []
i = 0
while i < len(nums1):
j = 0
while j < len(nums2):
if nums1[i] == nums2[j]:
newNums.append(nums2[j])
del nums1[i], nums2[j]
i -= 1
j -= 1
break
j += 1
i += 1
return newNums # print(intersect([9],[7,8,3,9,0,0,9,1,5])) # 加1
def plusOne(digits):
strDigits = ''
for example in digits:
strDigits += str(example)
strDigits = int(strDigits) + 1
listDigits = [int(str) for str in str(strDigits)]
return listDigits # print(plusOne([1, 2, 3])) # 移动0
def moveZeroes(nums):
# for i in range(len(nums)):
i = 0
zeroesCount = 0
while i + zeroesCount < len(nums):
if nums[i] == 0:
nums[i:] = nums[i + 1:] + [0]
i -= 1
zeroesCount += 1
i += 1
return nums # 两数和
def twoSum(nums, target):
d = {}
for x in range(len(nums)):
a = target - nums[x]
if nums[x] in d:
return d[nums[x]], x
else:
d[a] = x nums = [3, 2, 4]
target = 6 # print(twoSum(nums, target)) def isXT(strs):
strSet = set(strs)
for s in strSet:
if s != ".":
if strs.count(s) > 1:
return False
return True # 有效的数独
def isValidSudoku(board):
for i in range(9):
boardLie = [example[i] for example in board]
key1 = int(i / 3) * 3 + 1
key2 = 1 + (i % 3) * 3
boardGe = [board[key1 - 1][key2 - 1], board[key1 - 1][key2], board[key1 - 1][key2 + 1],
board[key1][key2 - 1], board[key1][key2], board[key1][key2 + 1],
board[key1 + 1][key2 - 1], board[key1 + 1][key2], board[key1 + 1][key2 + 1]]
if isXT(board[i]) == False:
return False
if isXT(boardLie) == False:
return False
if isXT(boardGe) == False:
return False
return True board = [[".", ".", "4", ".", ".", ".", "6", "3", "."],
[".", ".", ".", ".", ".", ".", ".", ".", "."],
["5", ".", ".", ".", ".", ".", ".", "9", "."],
[".", ".", ".", "5", "6", ".", ".", ".", "."],
["4", ".", "3", ".", ".", ".", ".", ".", "1"],
[".", ".", ".", "7", ".", ".", ".", ".", "."],
[".", ".", ".", "5", ".", ".", ".", ".", "."],
[".", ".", ".", ".", ".", ".", ".", ".", "."],
[".", ".", ".", ".", ".", ".", ".", ".", "."]] # print(isValidSudoku(board))
# 旋转图像
def rotate(matrix):
for i in range(len(matrix)):
for j in range(i+1,len(matrix)):
matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j]
matrix[i].reverse()
print(matrix) ma = [
[1, 2, 3],
[4, 5, 6],
[7, 8, 9]
]
rotate(ma)

LeetCode初级算法的Python实现--数组的更多相关文章

  1. LeetCode初级算法的Python实现--排序和搜索、设计问题、数学及其他

    LeetCode初级算法的Python实现--排序和搜索.设计问题.数学及其他 1.排序和搜索 class Solution(object): # 合并两个有序数组 def merge(self, n ...

  2. LeetCode初级算法的Python实现--链表

    LeetCode初级算法的Python实现--链表 之前没有接触过Python编写的链表,所以这里记录一下思路.这里前面的代码是和leetcode中的一样,因为做题需要调用,所以下面会给出. 首先定义 ...

  3. LeetCode初级算法的Python实现--字符串

    LeetCode初级算法的Python实现--字符串 # 反转字符串 def reverseString(s): return s[::-1] # 颠倒数字 def reverse(x): if x ...

  4. LeetCode初级算法的Python实现--动态规划

    动态规划的本质是递归:所以做题之前一定要会递归:递归式就是状态转移方程:这里将会介绍使用动态规划做题的思维方式. 统一的做题步骤: 1.用递归的方式写出代码:(此方法写的代码在leetcode中一定会 ...

  5. LeetCode初级算法之数组:48 旋转图像

    旋转图像 题目地址:https://leetcode-cn.com/problems/rotate-image/ 给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: ...

  6. LeetCode初级算法--数组01:只出现一次的数字

    LeetCode初级算法--数组01:只出现一次的数字 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn. ...

  7. LeetCode初级算法--数组02:旋转数组

    LeetCode初级算法--数组02:旋转数组 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/ ...

  8. LeetCode初级算法--设计问题01:Shuffle an Array (打乱数组)

    LeetCode初级算法--设计问题01:Shuffle an Array (打乱数组) 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:h ...

  9. LeetCode初级算法(数组)解答

    这里记录了LeetCode初级算法中数组的一些题目: 加一 本来想先转成整数,加1后再转回去:耽美想到测试的例子考虑到了这个方法的笨重,所以int类型超了最大范围65536,导致程序出错. class ...

随机推荐

  1. centos7 nginx访问目录403解决

    查看  /usr/sbin/sestatusSELinux status是不是enabled  然后 vi /etc/selinux/config修改:SELINUX=disabledreboot

  2. crt文件上传下载

    为了方便修改文件,下载与修改服务器文件,便利很多啊! 主要命令: sz filename #下载 rz 参数 #上传 弹窗选择文件 如果没有安装请装工具: yum install lrzsz man ...

  3. UNIX和linux系统性能监控工具oswatcher

    可以在一台机器上运行oswatcher.把运行的结果拷贝到有vnc的机器上进行分析.java -jar oswbba.jar -i /mnt/hgfs/database/oswbb/archive . ...

  4. 你不能不知道到的Hook!

    Hook是什么?     hook翻译之后是钩子的意思,hook的用途主要是用来拦截消息的,看到这里大家可能会迷茫,What is a hook?所以这时就不得不普及一下操作系统的原理. 举个例子:假 ...

  5. U-Mail邮件群发:邮件营销最全建议

    U-Mail专注于邮件营销平台研发工作多年了,服务企业数千家,拥有上万IP,在国内外基础设施建设上投资巨大,技术团队精湛.客服人员热情,赢 得了业界的好评和用户信任.有一些用户给我们发来邮件或来电咨询 ...

  6. tp5中分页携带参数的方法

    $list = $model->where(...)->order(.....)->paginate($size, false, [                'query' = ...

  7. 记录linux查询命令的一个网站

    http://man.linuxde.net/ 另外下面是对常用命令的总结 https://www.cnblogs.com/soyxiaobi/p/9717483.html

  8. idea中使用maven

    转:https://www.cnblogs.com/kagome2014/p/8431064.html 对于新版的IDEA可以直接打开Maven项目,但是对于旧版的IDEA需要使用Maven命令生成项 ...

  9. import(导入)过期的磁带 -----先留个引子,后期更改补充

    在某些情况下,客户需要恢复已经过期的磁带上的数据, 如果磁带没有被重新使用,数据没有被覆盖掉,可以使用 netbackup 的 import 方法将过期的磁带上的数据 import 到 netback ...

  10. HDU 1009 FatMouse' Trade(简单贪心 物品可分割的背包问题)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1009 FatMouse' Trade Time Limit: 2000/1000 MS (Java/O ...