标签:off and iterator struct subject tle 另一个 rand label
/* struct RandomListNode { int label; struct RandomListNode *next, *random; RandomListNode(int x) : label(x), next(NULL), random(NULL) { } }; */ class Solution { public: RandomListNode* Clone(RandomListNode* pHead) { if(pHead == NULL){ return NULL; } map<RandomListNode*,RandomListNode*>tmpMap; RandomListNode* p1 = NULL; RandomListNode* p2Head = NULL; RandomListNode* tmpHead = pHead; if(tmpHead){ p1 = new RandomListNode(tmpHead->label); p2Head = p1; tmpMap[tmpHead] = p1; tmpHead = tmpHead->next; } while(tmpHead){ RandomListNode* tmp = new RandomListNode(tmpHead->label); p1->next = tmp; p1 = tmp; tmpMap[tmpHead] = tmp; tmpHead = tmpHead->next; } tmpHead = pHead; map<RandomListNode*,RandomListNode*>::iterator it; map<RandomListNode*,RandomListNode*>::iterator it_random; while(tmpHead){ if(tmpHead->random){ it = tmpMap.find(tmpHead); if(it != tmpMap.end()){ it_random = tmpMap.find(tmpHead->random); if(it_random != tmpMap.end()){ it->second->random = it_random->second; } } } tmpHead = tmpHead->next; } return p2Head; } };
标签:off and iterator struct subject tle 另一个 rand label
原文地址:https://www.cnblogs.com/grglym/p/8994911.html