컴공일기263
게시글 주소: https://orbi.kr/00071243744
자료구조의 기본인 싱글 링크드 리스트를 C++ 버전으로 간단히 구현한 예제입니다.
OOP답게 노드, 링크드 리스트, 이터레이터의 클래스가 정의되고
각각의 객체가 가져야 하는 기능을 구현한 것이지요.
사실, 핵심에 초점을 맞추어 구현했기 때문에
상용화를 시키기엔 “매우 매우” 무리가 있습니다.
당장, 리스트의 중간에 삽입하는 로직도 없고
무엇보다 더미헤드를 가지지 않은 상황이라 비효율적이고
딥 카피 기반의 복사 생성도 지원하지 않지요.
또 충격적인 건, 이미 STL에서 forward_list를 지원하고 있습니다.
이 코드보다 훨씬 더 정교하고, 신뢰성있고, 효율적인 라이브러리를 이미 C++에서는 지원하고 있죠.
즉, C++에서 구현해 놓은 좋은 라이브러리를 가져다 쓰면 될 일입니다.
그러면 왜 이런 코드를 짠 걸까.
간단합니다. STL은 저와 같은 “사용자” 입장에서 구현과 상세가 감추어졌습니다.
따라서, 제 입장에선 STL 리스트의 전반적 구조를 모릅니다. 그런데 말입니다.
“잘 가져다 쓴다는 건”, 내부적인 상황을 어느정도는 알 때 가능한 일입니다.
이 라이브러리가 어떤 구조를 갖고 있는지를 아예 모르는 상태라면, 자칫 이 라이브러리 구조에서
절대 하면 안 될 짓거리들을 하기 마련이죠. 라이브러리를 잘 쓰려면, 우선 하지 말아야 할 걸 알아야 하고
이 말은 결국… 어느 정도의 구조는 알고 있어야 된다는 걸 의미하죠.
따라서, 완벽하고 확실하게는 아니어도 이런 방식으로 흉내내면서 전체적인 구조를 파악할 필요가 있습니다.
OOP에서는 구조가 너무나도 중요한 핵심이니까요. 구조에 따라서, 해야 할 짓과 안 해야 할 짓이 나뉩니다.
안해야 할 짓을 해야 할 짓으로 착각하고 이용한다면?
야근 시간이 길어지겠죠?
#include <iostream>
using namespace std;
class Node
{
public:
explicit Node(int value) : data(value), next(nullptr) {};
//getter
Node* getNext() const
{
return next;
}
int& getData()
{
return data;
}
//setter
void setNext(Node* nextNode)
{
next = nextNode;
}
void setData(int value)
{
data = value;
}
private:
int data;
Node* next = nullptr;
};
class Linked_List
{
public:
Linked_List() : head(nullptr) {};
~Linked_List()
{
Node* tmp = head;
while(tmp != nullptr)
{
Node* pDelete = tmp;
cout << "delete " << pDelete->getData() << endl;
tmp = tmp->getNext();
delete pDelete;
}
}
void insertAtHead(int value)
{
Node* newNode = new Node(value);
if(head == nullptr)
{
head = newNode;
}
else
{
newNode->setNext(head);
head = newNode;
}
}
void remove(int value)
{
//헤드 노드를 삭제하는 경우
if(head->getData() == value)
{
Node* pDelete = head;
head = pDelete->getNext();
delete pDelete;
return;
}
//헤드가 아닌 노드를 삭제하는 경우
Node* pDelete = head->getNext();
Node* pPrevious = head;
while(pDelete->getData() != value)
{
pDelete = pDelete->getNext();
pPrevious = pPrevious->getNext();
}
pPrevious->setNext(pDelete->getNext());
delete pDelete;
}
void getList()
{
Node* tmp = head;
while(tmp != nullptr)
{
cout << tmp->getData() << " ";
tmp = tmp->getNext();
}
cout << endl;
}
class Iterator
{
public:
explicit Iterator(Node* Node) : current(Node) {}
int& operator*() const
{
return current->getData();
}
Iterator& operator++()
{
if(current) current = current->getNext();
return *this;
}
bool operator!=(const Iterator& other)
{
return current != other.current;
}
private:
Node* current;
};
Iterator begin()
{
return Iterator(head);
}
Iterator end()
{
return Iterator(nullptr);
}
private:
Node* head;
};
int main()
{
Linked_List list;
list.insertAtHead(1);
list.insertAtHead(2);
list.insertAtHead(3);
list.insertAtHead(4);
Linked_List::Iterator it = list.begin();
for(auto it = list.begin(); it != list.end(); ++it)
{
*it *= 3;
}
list.getList();
}
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
어려웠나요
-
우리의 주적 2
간부
-
이명학 풀커리 타는건 너무 시간낭비 같나요 그냥 일리 기초강의만 듣고 알아서...
-
오 센츄리온달림 4
즐겁다
-
멘토링 받는 학생들 학습욕을 고취시킬 방법을 찾으라는데 4
어케해야될지 감이 안옴 하기싫다 그러면 연고 합응이나 연고전 영상같은거 틀어줌,,?
-
바로 확인해봤는데 아직 처리중이네..
-
얼버기 10
-
3덮 화2생2 2
기숙사 살아서 주말에 집가면 풀어보려는데 범위가 어케되나요
-
김승리 kbs 0
김승리 kbs 언제 입고되나요? 20일날 한다 했는데
-
실시간 ㅈ됐다 1
학교가는데 급하게 나온다고 버즈 두고 와버렸따... 아아아아아ㅏ
-
강기분 독서랑 문학 원래는 민철t가 올려준 학습 계획표대로 1주차 2주차 이렇게...
-
내손잡아서 직접해주심
-
•국어 -전형태 문학 올인원 -전형태 나BS •수학 -장영진 BTK -장영진 꿀모...
-
이 글 공감되네 2
https://orbi.kr/00068907447/Me-after-2024-CSAT-...
-
원래는 고딩때 일진 눈도 못마주치고쓰레기 아무데나 버리고 침 찍찍 뱉고...
-
모고2-3등급이 주말 이틀동안 풀면 스텝1 100문제 정도는 풀 수 있을까요?...
-
24수능때 국어 영어 1 받긴 했는데 25는 입시 끝나서 스킵했는데, 올해 문득...
-
스읍..
-
“드디어 집에 간다”…눈사태 고립 백여 명 17시간 만에 귀가 3
[앵커] 어제(18일) 강원도 산간지역에 폭설이 쏟아지면서 고지대에 위치한 대학...
-
전공서적 수백 페이지 읽을 능력 미분 방정식 풀 능력 수능 국어 수학에서 비롯...
-
더프화2후기 7
더프 20분컷은 처음 해봄. 예년보다 확실히 쉬움 평소에 더프 화2에서 보이던...
-
대충 용돈까지 포함하면 생각보다 나쁘지않은듯 그 안에서 술먹고 밥먹고 옷사고...
-
중고로 작년꺼 구입하려하는데 두분 중 누구꺼가 더 퀄이 좋나요?
-
"선배들 눈치 보느라..." 입학식만 참석, 알바 찾는 의대 신입생 1
[파이낸셜뉴스] "부모님은 어떠한 일이 있어도 학교에 가라 하고, 선배들은 어떠한...
-
어 형이랑 논술준비하면 그만이야
-
1컷이 어케 만점임?? 하... 57점 만점에 39점 맞았는데 갈길이 멀다...
-
직각이등변 무한 이용 3월엔 접선 안들어가니 이차식계산함 계산산산
-
어제 반 누구 예쁘게ㅜ생겼다고 하니까 고백하라고 놀림받음
-
기숙장학가격 0
기숙학원 갈라는데 수업료 100프로 면제거든요 그럼 얼마정도 할까요..??찾아봐도 안나와서
-
수능으로 부등식만들어쥬세요
-
책아깝다 0
확통 아이디어 하고있었는데 과외쌤이 스블 페메로 바꾸라 그럼 한 절반 남았는데 걍 버리는 건가
-
제205차 에피/센츄리온 심사 결과 (25년 2월) 11
본 제205차 심사는 2025년 2월 1일부터 2월 28일까지 접수된 신청에 대한...
-
수학 N제중에선 0
4드문이가 제일 좋은건가요?
-
작수 국수생1 만점 20
과외 구하기 왜케 어렵지 시급을 너무 높게 불러서 그릉가
-
아직 배송중인데
-
https://www.veritas-a.com/news/articleView.html...
-
너는 잊지 않기를 바라느냐? 잊지 않는 것이 병이 아닌 것은 아니다.
-
나기억하니?
-
똥글만싸다찔렸는지이제서야푸는ww
-
스팀세일 오늘까지임 빨리 ㄱㄱ
-
아 아니 2
아악 내풀콤을돌려조
-
등급은 나오는데 백분위는 없네요 원래 안주나요?
-
오늘은 독재를 무슨 일이 있어도 가겠음
-
올오카 컨텐츠를 푼다던지 할때, 뭔가 독서같은 경우는 정답 근거?가 명확하게...
-
매일매일을 주말같이 살다가 개강하고 두 주 연속 주말 없이 살았더니 죽을거같다
-
생1은 시험장에서 변수도 많고 2문제는 거의 찍다시피 하는거같던데 고정점수 만들 수...
-
대학교 1교시 9시 더 힘들어
-
무휴학반수 0
무휴학 반수할때 수능접수는 어케하나요? 출신고등학교 입력할때 따로 잇올같은...

반가워요 새해복 많이 받으세여