내 소식

✨컴공주✨ [1052682] · MS 2021 (수정됨) · 쪽지

2023-12-24 10:16:09
조회수 1,462

컴공 일기237

게시글 주소: https://dev.orbi.kr/00066109820


예… 이제 C++로 언어를 바꿨습니다.

사실, C로 자료구조를 만드는 것과 방식이 약간(어쩌면 아주 많이)다릅니다.


객체지향의 세계관으로 들어오는 순간, class와 탬플릿이 나타나기 시작하죠. 어떻게 보면 객체지향으로 들어오는 순간 개발자 관점과 사용자 관점을 분리해서 생각해야 되는 것 같습니다.


자료구조는 원형 더블링크드리스트인데, iterator로 출력을 하기 위해서나 / 삭제 로직을 비교적 쉽게 구현하기 위해서나 dummy 노드(처음 순서에 들어가는 이름없는 노드)를 생성하자는 것이 리스트의 결론이죠.


뭔가 링크드 리스트로 효율을 생각하는 순간 “더미 노드”를 만들자!로 의견이 모인달까요.


아, 군대에 있는 관계로 코딩은 아이패드로 진행하고 있습니다.


// Created on iPad.


#include <iostream>

using namespace std;


template <typename T>

struct cir_list_node

{

    T* data;

    cir_list_node* next;

    cir_list_node* prev;


    ~cir_list_node()

    {

        delete data;

    }

};


template <typename T>

struct cir_list

{

public:

    using node = cir_list_node<T>;

    using node_ptr = node*;


private:

    node_ptr head;

    size_t n;


public:

    cir_list() : n(0) 

    {

       head = new node{NULL, NULL, NULL};

       head->next = head;

       head->prev = head;   

    }


    size_t size() const

    {

        return n;

    }


    void insert(const T& value)

    {

        node_ptr newNode = new node{new T(value), NULL, NULL};

        n++;

        auto dummy = head->prev;

        dummy->next = newNode;

        newNode->prev = dummy;

        

        //원형 리스트에 원소의 개수가 0인 경우

        if(head == dummy)

        {

           dummy->prev = newNode;

           newNode->next = dummy;

           head = newNode;

           return;

        }


        newNode->next = head;

        head->prev = newNode;

        head = newNode;

    }


    void erase(const T& value)

    {

       auto cur = head, dummy = head->prev;

       while(cur != dummy)

       {

        if(*(cur->data) == value)

        {

            cur->prev->next = cur->next;

            cur->next->prev = cur->prev;

            if(cur == head)

                head = head->next;

            delete cur;

            n--;

            return;

        }

        cur = cur->next;

       }

    }


    struct cir_list_it

    {

    private:

        node_ptr ptr;


    public:

        cir_list_it(node_ptr p) : ptr(p) {}


        T& operator*()

        {

            return *(ptr->data);

        }

 

        node_ptr get()

        {

            return ptr;

        }


        cir_list_it& operator++()

        {

            ptr=ptr->next;

            return *this;

        }


        cir_list_it operator++(int)

        {

            cir_list_it it = *this;

            ++(*this);

            return it;

        }


        cir_list_it& operator--()

        {

            ptr = ptr->next;

            return *this;

        }


        cir_list_it operator--(int)

        {

            cir_list_it it = *this;

            --(*this);

            return it;

        }


        friend bool operator==(const cir_list_it& it1, const cir_list_it& it2)

        {

            return it1.ptr == it2.ptr;

        }


        friend bool operator!=(const cir_list_it& it1, const cir_list_it& it2)

        {

            return it1.ptr != it2.ptr;

        }

    };


    cir_list_it begin()

    {

        return cir_list_it{head};

    }                

        

    cir_list_it begin() const

    {

        return cir_list_it{head};

    }


    cir_list_it end()

    {

        return cir_list_it{head->prev};     

    }


    cir_list_it end() const

    {

        return cir_list_it{head->prev};

    }


    cir_list(const cir_list<T>& other) : cir_list()

    {

        //아래 코드는 원소를 역순으로 삽입하지만,

        //원형 연결리스트이므로 상관없다.

        for(const auto& i : other)

            insert(i);

    }


    cir_list(const std::initializer_list<T>& il) : head(NULL), n(0)

    {

        for(const auto& i : il)

            insert(i);

    }


    ~cir_list()

    {

        while(size())

        {

            erase(*(head->data));

        }


        delete head;

    }

};



struct playlist

{

    cir_list<string> list;


    void insert(const string song)

    {

        list.insert(song);

    }


    void erase(const string song)

    {

        list.erase(song);

    }


    void loopOnce()

    {

        for(auto& song : list)

            cout << song << endl;


        cout << endl;

    }

};


int main() {

    playlist mp3;

    mp3.insert("Re:plus - Pulse");

    mp3.insert("Kebee - 고3후기");

    mp3.insert("Soul company - 천국에도 그림자는 진다");


    cout << "재생목록: " << endl;

    mp3.loopOnce();


    playlist Youtube_Premium = mp3;

    Youtube_Premium.insert("Don-Malik - 전염");

    Youtube_Premium.insert("LeellaMarz - Trip");


    cout << "유튜브 오프라인 재생목록" << endl;

    Youtube_Premium.loopOnce();

    }

rare-백예린입니다

0 XDK (+0)

  1. 유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.

✨컴공주✨ [1052682]

쪽지 보내기

  • 미리이에 · 897568 · 23/12/24 10:17 · MS 2019

    글 잘 보고 있습니다! 혹시 아이패드로 코딩하기 좋은 앱 추천해주실 수 있을까요

  • ✨컴공주✨ · 1052682 · 23/12/24 10:20 · MS 2021

    저는 지금, CodeApp인가요? 유료 버젼 쓰고 있습니다. 운영체제나 컴구 쪽을 공부하다 보면 스레드를 만들 일이 있는데(Multi-Threading), 이 앱은 실험해보니 스레드 생성 시스템 콜은 지원해주지 않는 것 같았어요.

    그래서, 아이패드에서 운영체제 쪽 코드를 공부할 일이 있으면 ISH Shell이라는 앱을 씁니다. Alpine Linux 계통이라 gcc / 표준 라이브러리 같은 것들이 apk 형식으로 다운받을 수 있어서 아이패드에서 리눅스 환경을 사용할 수 있습니다.

    참고하시기 바랍니다.

  • 미리이에 · 897568 · 23/12/24 10:22 · MS 2019

    정말 감사합니다!!! 오늘도 좋은 하루 되세요
  • 민족고대컷 · 1241577 · 23/12/24 10:19 · MS 2023

  • ✨컴공주✨ · 1052682 · 23/12/24 10:23 · MS 2021

  • 긍정미분 · 1208323 · 23/12/24 10:24 · MS 2023

    오랜만입니다.. 방굽습니다
  • ✨컴공주✨ · 1052682 · 23/12/24 10:36 · MS 2021

    안녕하세용 ~_~

  • 주연 · 1141364 · 23/12/24 10:51 · MS 2022

    성대 지능형소프트웨어학과에 관심이 있는데여
    사진에 있는게 학사과정 로드맵인데 컴공보다 많이 뻑세려나요??

  • ✨컴공주✨ · 1052682 · 23/12/24 11:00 · MS 2021

    우선… 많이 힘들다고 보여집니다. 물론 저 과목들을 다 이수해야 하는 것은 아닐 테지만, 1학년 때 자구와 컴구를 동시에 배운다는 게 꽤 놀랍긴 하네요.

    이론적으로 성대 솦이면 매우 뛰어난 사람들이 가는 곳이긴 하지만… 그럼에도 코딩을 처음 배우는 사람에겐 부담이 매우 많이가는 커리큘럼으로 보여집니다.

    처음에 언어 문법 하나 익히기도 어려운 게 현실인데, 거기에 컴구 + 자구를 6개월 안에 해치운다는 건… 아주 어렵죠.

    뿐만이 아니라 인공지능론까지 배우니… ㅋㅋㅋ
    그냥 새벽까지 코딩하지 않으면 학점 관리 자체가 안 될 수도 있을 것 같습니다.

  • ✨컴공주✨ · 1052682 · 23/12/24 11:03 · MS 2021 (수정됨)

    제가 생각하기에는 아마 1학년으로 편성된 과목들을 재수강해서 3-4학년 즈음에 다시 듣는 것이 훨씬 이득인 것도 같습니다 ㅋㅋㅋ

    컴구와 운체에 대한 전체적인 흐름을 알게 되면 그때 ‘시스템 프로그래밍’이나 네트워크론을 공부할 때 좋은 효율이 나오거든요…

  • 주연 · 1141364 · 23/12/24 11:14 · MS 2022

    재수강까지 ㄷㄷ.. 미리 공부해야 좀 나을려나요 ㅠ

  • ✨컴공주✨ · 1052682 · 23/12/24 11:22 · MS 2021

    미리 공부하는 것도 괜찮습니다만, 우선 시간이 나실 때 편안한 마음으로 해보세요. 처음에는 즐기면서 공부해야 나중에 체력이 길러집니다.

  • ✨컴공주✨ · 1052682 · 23/12/24 11:23 · MS 2021

    물론, 이건 학부생의 개인적인 견해이고 상황에 따라서는 저 커리큘럼을 소화만 할 수 있다면 정말 좋은 건 맞아 보입니다.

  • ExtremeWaist · 957403 · 23/12/24 20:59 · MS 2020

    자구 알고리즘은 뭐 그렇다 쳐도 신호시스템이나 운영체제 2학년은 좀 많이 빡센데... 보통 이런 과 특징이 과목이름은 타 학교와 같지만 내용은 좀 약화하고 대신 넓게 건드릴 확률이 있어요. 인공지능에 초점을 꽤 두는 학과인건가요? 인공지능개론이나 기계학습수학, 기계학습원론, 심층 신경망 개론 이것들은 굳이 이렇게 쪼개지 않아도 될 것 같은데 아마 이것도 얕게 배울것 같아요. 컴구도 개론이라고는 하지만 적어도 논리회로 제대로 하고나서 베릴로그로 2-3학년때나 건드릴 수 있는데, 저건 그냥 정말 기초적인 회로 위주로 다루나 보네요.