重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
題目描述:輸入一個鏈表的頭結點,從尾到頭反過來打印出每個節點的值
鏈表的節點定義如下:
struct ListNode { int m_nValue; ListNode* m_pNext; };
分析:
一般情況下,遇到這種問題,首先應該問清楚面試官是否可以改變原有的鏈表結構,自己再做分析。
void PrintListReversingly_Iteratively(ListNode* pHead) { std::stacknodes; ListNode* pNode = pHead; while(pNode != NULL) { nodes.push(pNode); pNode = pNode->m_pNext; } while(!nodes.empty()) { pNode = nodes.top(); printf("%d\t", pNode->m_nValue); nodes.pop(); } }
void PrintListReversingly_Recursively(ListNode* pHead) { if(pHead != NULL) { if (pHead->m_pNext != NULL) { PrintListReversingly_Recursively(pHead->m_pNext); } printf("%d\t", pHead->m_nValue); } }
說明:用遞歸的代碼看起來很簡潔,但是如果一個鏈表非常長,于是遞歸調用的深度越深,就有可能導致棧溢出,因此利用循環實現的代碼的魯棒性(健壯性)會更好些。
創新互聯www.cdcxhl.cn,專業提供香港、美國云服務器,動態BGP最優骨干路由自動選擇,持續穩定高效的網絡助力業務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節活動現已開啟,新人活動云服務器買多久送多久。