面试题13: 机器人的运动范围
题目:地上有一个m行和n列的方格。一个机器人从坐标0,0的格子开始移动,每一次只能向左,右,上,下四个方向移动一格,但是不能进入行坐标和列坐标的数位之和大于k的格子。 例如,当k为18时,机器人能够进入方格(35,37),因为3+5+3+7 = 18。但是,它不能进入方格(35,38),因为3+5+3+8 = 19。请问该机器人能够达到多少个格子?
解题思路:回溯体现在迭代中,所以算法肯定是一个迭代的算法,然后,因为统计的是能够达到的格子数量,所以可以为每个格子做一个标记(二维数组),标记为0时表示这个已经是能够达到的格子。,用类属性count统计可达到的格子数量。
代码:
1 | class Solution: |
代码思路:arr和count写在迭代外面,是global的值。list(map(int, list(str(i))))这个的意思是,先将字符串转换成str的list,然后用一个map将这些str转成int,然后在生成list。每个findway里面有四个迭代函数,表示向上下左右进行搜索。
面试题14:剪绳子
题目:给你一根长度为n的绳子,请把绳子剪成整数长的m段(m、n都是整数,n>1并且m>1),每段绳子的长度记为k[0],k[1],…,k[m]。请问k[0]xk[1]x…xk[m]可能的最大乘积是多少?例如,当绳子的长度是8时,我们把它剪成长度分别为2、3、3的三段,此时得到的最大乘积是18。
解题思路:这题可以用贪婪算法来求解。原因如下:
算法:
1 | class Solution: |
算法思路:就是先写出最简单的情况,然后尽量使得3的数量最多,当最后一段可以为4时,就让它为4,而不是3和1。最后就是n个3和m个2。