阅读量:0
【21题,合并两个有序链表】
思路:递归:
1、如果q为NULL,p为NULL;返回NULL;
2、如果q为NULL,返回p;
3、如果p为NULL,返回 q;
4、判断两数大小,p小于等于q返回p,p->next递归调用函数
5、否则返回q,q->next递归调用函数
代码:
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) { struct ListNode* p = list1; struct ListNode* q = list2; if(q==NULL && p==NULL) { return NULL; } else if(q==NULL) { return p; } else if(p==NULL) { return q; } if(p->val <= q->val) { p->next = mergeTwoLists(p->next,q); return p; } q->next = mergeTwoLists(p,q->next); return q; }
思路:使用迭代的方法
1、定义头尾节点,
2、遍历判断两个链表的单个值,用尾插法将小的值代入链表
代码:
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) { struct ListNode* p = list1; struct ListNode* q = list2; struct ListNode *tail = NULL; struct ListNode *head = NULL; if(q==NULL && p==NULL) { return NULL; } else if(q==NULL) { return p; } else if(p==NULL) { return q; } while(p != NULL && q!=NULL) { struct ListNode *pnew = (q->val <= p->val)? q:p; if(head == NULL) { head = pnew; tail = pnew; } else { tail->next = pnew; tail = pnew; } if(q->val <= p->val) { q=q->next; } else { p= p->next; } } tail->next = (q==NULL)?p:q; return head; }
【环形链表】
思路:暴力求解
1、将所有遍历过的值全部替换为100001
2、判断如果遇到NULL则返回false
3、如果遇到大于100000的数则返回true;
代码:
/** * Definition for singly-linked list. * struct ListNode { * int val; * struct ListNode *next; * }; */ bool hasCycle(struct ListNode *head) { if(head == NULL) { return false; } struct ListNode *p = head; int temp = 10000; while(1) { p->val = 100001; p = p->next; if(p == NULL) { return false; break; } else if(p->val > 100000) { return true; break; } } }