54、Spiral Matrix
题目:
题目意思很简单,就是螺旋式访问矩阵元素。也没有比较经典的算法可以解决此题,只需要模拟一下这个过程即可。
代码如下:
1 class Solution { 2 public: 3 vector<int> spiralOrder(vector<vector<int>>& matrix) { 4 vector<int> res; 5 if(matrix.empty()) 6 return res; 7 int m = matrix.size(); 8 int n = matrix[0].size(); 9 10 11 int i,j; 12 13 bool **arr = new bool*[m]; 14 for(i=0;i<m;i++) 15 { 16 arr[i] = new bool[n]; 17 memset(arr[i],0,sizeof(bool)); 18 } 19 20 int flag=0;//0表示向右,1表示向下,2表示向左,3表示向上 21 22 int count = 0; 23 i=0; 24 j=0; 25 while(true) 26 { 27 res.push_back(matrix[i][j]); 28 arr[i][j] = true; 29 count++; 30 if(count == m*n) 31 break; 32 33 34 if(0 == flag) 35 { 36 j++; 37 } 38 else if(1 == flag) 39 i++; 40 else if(2 == flag) 41 j--; 42 else 43 i--; 44 45 if(i<0 || i>=m || j<0 || j>=n || arr[i][j])//越界了或者访问到已经被访问过的元素 46 { 47 48 if(i<0) 49 i=0; 50 if(j<0) 51 j=0; 52 if(i>=m) 53 i=m-1; 54 if(j>=n) 55 j=n-1; 56 if(arr[i][j]) 57 { 58 if(0 == flag) 59 j--; 60 61 else if(1 == flag) 62 i--; 63 else if(2 == flag) 64 j++; 65 else 66 i++; 67 } 68 69 flag = (flag + 1)%4; 70 res.pop_back(); 71 count--; 72 } 73 74 } 75 return res; 76 77 } 78 };
-----------------------------------------------------------------------分割线-----------------------------------------------------------------------
55、Jump Game
题目:
分析:针对数组中每一个元素,计算其最大能跳多远,并将这个最远值记录好。
代码如下:
1 class Solution { 2 public: 3 bool canJump(vector<int>& nums) { 4 const int size = nums.size(); 5 int index = 0; 6 int max = 0; 7 for(;index<=size-1-1;index++)//注意等号, 8 { 9 if(index + nums[index] > max) 10 max = index + nums[index]; 11 if(index >= max)//针对用例[0,1,2] 12 return false; 13 } 14 if(max >= size-1) 15 return true; 16 else 17 return false; 18 } 19 };
-------------------------------------------------------------------------------分割线-------------------------------------------------------------------
58、Length of Last Word
题目
题目很简单,直接贴代码
1 class Solution { 2 public: 3 int lengthOfLastWord(const char *s) { 4 int len=strlen(s); 5 int sum=0; 6 while(s[len-1]==' ') len--; 7 for(int i=len-1;i>=0;i--) 8 { 9 if(s[i]!=' ') sum++; 10 else break; 11 } 12 return sum; 13 } 14 };