标签:
唉,这么简单的东西,说简单是简单,关键是要把这东西写得好,老少兼知。应对所有测试用例,那就有点难了吧。
#ifndef COMBINE_TWO_LIST_H
#define COMBINE_TWO_LIST_H
#include"reverseList.h"
ListNode *combineTwoList(ListNode *alist,ListNode *blist){
if(alist==NULL&&blist!=NULL){
return blist;
}
if(alist!=NULL&&blist==NULL){
return alist;
}
if(alist==NULL&&blist==NULL){
return NULL;
}
ListNode *preList=alist;
ListNode *bckList=blist;
ListNode *rootIndex=NULL;
if(preList->val>=bckList->val){
rootIndex=bckList;
bckList=bckList->nxt;
}else{
rootIndex=preList;
preList=preList->nxt;
}
ListNode *result=rootIndex;
while(preList!=NULL&&bckList!=NULL){
if(preList->val>=bckList->val){
rootIndex->nxt=bckList;
rootIndex=rootIndex->nxt;
bckList=bckList->nxt;
}else{
rootIndex->nxt=preList;
rootIndex=rootIndex->nxt;
preList=preList->nxt;
}
}
if(preList==NULL){
rootIndex->nxt=bckList;
}
if(bckList==NULL){
rootIndex->nxt=preList;
}
return result;
}
#endif
if(preList==NULL){
rootIndex->nxt=bckList;
}
if(bckList==NULL){
rootIndex->nxt=preList;
}
int main(){
int arr1[4]={1,3,5,7};
int arr2[6]={2,4,8,8,8,10};
ListNode *root1=constructList(arr1,4);
ListNode *root2=constructList(arr2,6);
ListNode *root=combineTwoList(root1,root2);
printList(root);
}
#ifndef COMBINE_TWO_ARR_H
#define COMBINE_TWO_ARR_H
int *combineArr(int *arr1,int Len1,int *arr2,int Len2){
int *arr=new int[Len1+Len2];
int *arr1Iter=arr1;
int *arr2Iter=arr2;
int *arrIter=arr;
while(arr1Iter<=arr1+Len1-1&&arr2Iter<=arr2+Len2-1){
if(*arr1Iter<*arr2Iter){
*arrIter=*arr1Iter;
arrIter++;
arr1Iter++;
}else{
*arrIter=*arr2Iter;
arrIter++;
arr2Iter++;
}
}
if(arr1Iter>arr1+Len1-1){
while(arr2Iter<=arr2+Len2-1){
*arrIter=*arr2Iter;
arrIter++;
arr2Iter++;
}
}
if(arr2Iter>arr2+Len2-1){
while(arr1Iter<=arr1+Len1-1){
*arrIter=*arr1Iter;
arrIter++;
arr1Iter++;
}
}
return arr;
}
#endif
if(arr1Iter>arr1+Len1-1){
while(arr2Iter<=arr2+Len2-1){
*arrIter=*arr2Iter;
arrIter++;
arr2Iter++;
}
}
if(arr2Iter>arr2+Len2-1){
while(arr1Iter<=arr1+Len1-1){
*arrIter=*arr1Iter;
arrIter++;
arr1Iter++;
}
}
标签:
原文地址:http://www.cnblogs.com/yml435/p/4673794.html