80. Remove Duplicates from Sorted Array II

题目

分析:简单的操作,代码如下:

 1 class Solution {
 2 public:
 3     int removeDuplicates(vector<int>& nums) {
 4         int n = nums.size();
 5         if(0==n)
 6             return 0;
 7         
 8         int i=0;
 9         int temp;
10         int res = n;
11         vector<int> result;
12         int count;
13         for(i=0;i<n;)
14         {
15             temp=nums[i];
16             count=1;
17             i++;
18             while(i<n&&nums[i] == temp)
19             {
20                 count++;
21                 i++;
22             }
23                 
24             if(count>2)
25             {
26                 res = res-(count-2);
27                 result.push_back(temp);
28                 result.push_back(temp);
29                 
30             }
31             else
32                 while(count--)
33                 {
34                     result.push_back(temp);
35                 }
36                 
37         }
38         nums = result;
39         return res;
40         
41     }
42 };

 ---------------------------------------------------------------------------------分割线-----------------------------------------------------------------

81. Search in Rotated Sorted Array II

题目

分析:题目和33题很相识,代码如下:

 1 class Solution {
 2 public:
 3     bool search(vector<int>& nums, int target) {
 4         int n=nums.size();
 5         vector<int> A=nums;
 6          if(0 == n) return false;
 7         int left = 0; 
 8         int right = n - 1;
 9         while(left <= right)
10         {
11             int midle = (left + right) >> 1;
12             if(A[midle] == target) return true;
13             if(A[left] == A[midle] && A[midle] == A[right])
14             {
15                ++left;
16                --right;
17             }
18             else if(A[left] <= A[midle])
19             {
20                 if(A[left] <= target && target  < A[midle])
21                 {
22                     right = midle - 1;
23                 }
24                 else
25                 left = midle + 1;
26             }
27             else {
28                 if(A[midle] < target && target <= A[right])
29                     left = midle + 1;
30                 else
31                     right = midle - 1;
32             }
33         }
34         return false;
35     }
36 };

 --------------------------------------------------------------------------------分割线-----------------------------------------------------------------

82. Remove Duplicates from Sorted List II

题目

分析:这道题主要是考察指针操作,为了方便,在处理之前,对链表添加一个头节点,以便处理起来更加方便,代码如下

 1 /**
 2  * Definition for singly-linked list.
 3  * struct ListNode {
 4  *     int val;
 5  *     ListNode *next;
 6  *     ListNode(int x) : val(x), next(NULL) {}
 7  * };
 8  */
 9 class Solution {
10 public:
11     ListNode* deleteDuplicates(ListNode* head) {
12         if(NULL == head)
13             return NULL;
14         
15         ListNode *pre,*current;
16         ListNode *pHead = new ListNode(0);
17         pHead->next = head;//添加头节点
18         pre = pHead;
19         current = head;
20         int key;
21         bool flag = false;
22         while(current!= NULL)
23         {
24             key = current->val;
25             current = current->next;
26             while( current != NULL && current->val == key)
27             {
28                 flag = true;
29                 current = current->next;
30             }
31             if(flag)
32             {
33                 pre->next = current;
34                 flag = false;
35             }
36             else
37             pre = pre->next;
38         }
39         
40         return pHead->next;
41         
42     }
43 };

-------------------------------------------------------------------------分割线-------------------------------------------------------------------------

83. Remove Duplicates from Sorted List

分析:这一题和82题类似,代码如下:

 1 /**
 2  * Definition for singly-linked list.
 3  * struct ListNode {
 4  *     int val;
 5  *     ListNode *next;
 6  *     ListNode(int x) : val(x), next(NULL) {}
 7  * };
 8  */
 9 class Solution
10 {
11 public:
12     ListNode *deleteDuplicates(ListNode *head)
13     {
14         if(head==NULL || head->next==NULL) return head;
15         ListNode *helper = new ListNode(-100000);
16         ListNode *ret=head;
17         while(ret)
18         {
19             ListNode *next=ret->next;
20             if(ret->val!=helper->val)
21             {
22                 helper->next=ret;
23                 helper=ret;//将helper指新链表的尾结点
24                 helper->next=NULL;//尾指向空,因为后面的结点有可能被删去了,它不知道下一个指向谁
25             }
26             else delete ret;
27             ret=next;
28         }
29         return head;
30     }
31 };