[C/C++]단 방향 LinkedList 이용한 삽입,삭제,검색,갱신
- 공유 링크 만들기
- X
- 이메일
- 기타 앱
C나 C++을 이용할 때면,
LinkedList를 많이 쓰는데,
항상 쓸 때 마다 잊어 먹는 적이 많아서...
적어 두려 합니다.
LinkeList는
구조체로 되어있는 포인터에 다음 메모리 주소를 가르키는 link를 연결하여,
그 값에 접근 하는 형식의 구조를 띄고 있습니다.
LinkedList의 기본 개념은
구조체 안에 다음 구조체의 주소를 저장하는 개념입니다.
이런식의 선형적 구조를 띄는것이 일반적입니다.
이를 메모리에 나타내 보면
아마 위와 같은 그림으로 표현이 가능할 듯 싶습니다.
이를 토대로 기본적으로 구현해볼 기능은
CRUD(Create, Remove, Update, Delete) 기능입니다.
구조체를 일단 선언 합니다
char* / int / int 를 삽입하여 보겠습니다.
우선 삽입,
이런 식으로, 초기화 하는 부분,
Insert 하는 부분을 구분하여 구현 하신다면, 좀더 객관적으로 소스코드 분석 및
구현이 가능할 것입니다.
이를 토대로 List에 insert를 해보는 코드를 삽입하였고,
아래는 결과화면 입니다.
모든 값이 제대로 들어 간 것을 확인하실수 있습니다.
다음으로 삭제 입니다.
삭제의 경우에는 경우의 수가 존재합니다.
1) LinkedList의 처음 부분을 삭제하면서, next에 값이 존재 할 때,
mData->next에 값이 없다면 문제 될 것이 없습니다.
하지만, 값이 존재한다면, mData가 delete 되면서 mData->next의 주소를
찾을 수가 없습니다. 그렇기에 삭제 전에,
mData->next를 mData로 바꾸는 작업이 필요합니다.
2) LinkedList의 중간 부분을 삭제 할 때,
어떻게 보면, 가장 고려할 부분이 없을 것 같습니다.
단순히 mData->next 를 mData->next->next로 주소값을 바꿔 주는 작업만
수행하면 되기 때문입니다.
3) LiknedList의 마지막 부분을 삭제 할 때,
mData->next->next->next 를 NULL로 초기화 하는 작업을 수행하시면 문제 없을 것
같습니다.
왜 next->next->next를 NULL로 초기화 하냐면,
쓰레기 값을 가지는 주소를 가지고 있기 때문에,
(주소 값은 가지고 있는데, 구조체 안 값들이 쓰레기 값)
while(head != NULL)의 코드를 수행할 때, 에러를 발생하기 때문입니다.
다음으로 코드와 결과값 입니다.
순서대로 처음, 중간 마지막을 제거하는 방식으로 진행합니다.
경우의 수 3가지를 고려하여 삭제에 대해 수행합니다.
삭제 및 출력이 완료된 모습입니다.
갱신 및 검색의 경우도 삭제 연산의 while문을 참고하시면,
쉽게 구현하실 수 있으실 겁니다.
단방향 리스트의 경우나 양방향 리스트의 경우나 별 차이가 없기 때문에,
단순히 pre, next의 주소 값들의 설정 문제이기에, 크게 어렵지 않으실 겁니다.
아래는 전체 소스코드 입니다
// LinkedList.cpp : 콘솔 응용 프로그램에 대한 진입점을 정의합니다.
//
#include "stdafx.h" #includeusing namespace std; typedef struct Data{ int data; char* string; int size; Data* next; }Test; Test* mData; void InsertList(int data, char *buf, int size); Test* InitList(int data, char* buf, int size); void PrintTest(); void DeletePrint(); void DeletePrint(char* buf) { cout << buf << " / " << "삭제 완료" << endl << endl; } bool DeleteList(char* buf) // char 값을 통해 삭제할 데이터 구분 { Test* head = mData; Test* mTemp = NULL; while (head != NULL) { if (strcmp(buf, head->string) == 0) { if (head->next != NULL && mTemp != NULL){ // 리스트와 리스트 사이의 값을 삭제 시, mTemp->next = head->next; delete head; DeletePrint(buf); return true; }else if(head->next == NULL && mTemp != NULL)// 제일 끝 값을 삭제 시 { mTemp->next = NULL; delete head; DeletePrint(buf); return true; } else if (mTemp == NULL && head->next != NULL) // Head의 값을 삭제시 { mData = head->next; // 처음 값을 next로 지정 delete head; DeletePrint(buf); return true; } } mTemp = head; // 이전 리스트의 주소를 저장 head = head->next; // 다음으로 이동 } cout << "삭제할 값이 없습니다." << endl; return false; } void InsertList(int data,char *buf,int size) { if (mData == NULL) // Head 리스트가 NULL일 때, mData = InitList(data, buf, size); else { Test* head = mData; // mData로 search시 주소값이 변경되기에, 대체 리스트 생성 while (head->next != NULL) head = head->next; // 비어있는 리스트 탐색 head->next = InitList(data, buf, size); // 추가 } } Test* InitList(int data,char* buf,int size) { Test* mTest = new Test; mTest->data = data; mTest->string = new char[size]; memcpy(mTest->string, buf, size); mTest->size = size; mTest->next = NULL; return mTest; } // 초기화 및 할당 void PrintTest() { Test* head = mData; while (head != NULL) { cout << head->string << " / " << head->data << " / " << head->size << endl; head = head->next; } cout << endl; } int _tmain(int argc, _TCHAR* argv[]) { InsertList(0, "test0", 6); InsertList(1, "test1", 6); InsertList(2, "test2", 6); InsertList(3, "test3", 6); InsertList(4, "test4", 6); InsertList(5, "test5", 6); PrintTest(); DeleteList("test0"); PrintTest(); DeleteList("test3"); PrintTest(); DeleteList("test5"); PrintTest(); return 0; }
추가로 읽으면 좋을 것
단방향 linkedlist
링크드 리스트 구현
링크드 리스트 삽입
링크드 리스트 설명
링크드 리스트 C구현
링크드리스트 삭제
C
C/C++
C/C플플
CRUD
One Way Linked List
- 공유 링크 만들기
- X
- 이메일
- 기타 앱
댓글
이 블로그의 인기 게시물
윤석열 계엄령 선포! 방산주 대폭발? 관련주 투자 전략 완벽 분석
## 1. 배경 2024년 12월 3일, 윤석열 대통령이 국가 비상사태를 이유로 계엄령을 선포하였습니다. 계엄령은 전시나 사변 등 국가의 안녕과 공공질서가 심각하게 위협받을 때 대통령이 군사적 권한을 통해 이를 방어하고 유지하기 위해 발효하는 특별한 조치입니다. 이러한 조치는 국내 정치·경제 전반에 큰 영향을 미치며, 특히 주식시장에서는 관련 기업들의 주가 변동이 예상됩니다. 24.12.03 오전 5시 계엄 해제로 아래 관련주 추천 - [윤석열 계엄령 해제! 이재명 관련주 급등? 투자자 필독 전략](https://warguss.blogspot.com/2024/12/yoon-martial-law-lift-lee-jaemyung-stocks.html) --- ## 2. 기업 및 관련주 ### 2-1 식품 관련주 - 계엄령이 선포되면 사회적 불안정성이 증가할 수 있으며, 이에 따라 생필품 및 음식 관련 주식이 단기적으로 강세를 보일 가능성이 있습니다. #### 1. CJ제일제당 (KOSPI: 097950) [시가총액: 약 10조 원] - **주요 산업**: 식품 및 생필품 제조 - **관련주 근거**: 국가적 위기 상황에서 식료품 수요가 증가하며, 즉석밥, 가공식품 등의 판매가 확대될 가능성이 있습니다. - **주가정보**: [네이버 차트](https://finance.naver.com/item/main.nhn?code=097950) #### 2. 오뚜기 (KOSPI: 007310) [시가총액: 약 3조 원] - **주요 산업**: 식품 제조 및 유통 - **관련주 근거**: 라면, 즉석식품 등 비축 가능한 식품 수요가 증가하며, 매출 상승이 기대됩니다. - **주가정보**: [네이버 차트](https://finance.naver.com/item/main.nhn?code=007310) #### 3. 대상 (KOSPI: 001680) [시가총액: 약 2조 원] - **주요 산업**: 식품 제조 및 발효제품 - **관련주 근거**: 계엄...
대통령 퇴진운동 관련주: 방송·통신·촛불수혜주 완벽 분석
--- ## 1. 배경 2024년 12월 3일, 윤석열 대통령이 비상계엄령을 선포했으나, 짧은 시간 내에 이를 해제하면서 정치적 긴장감이 커졌습니다. 이에 따라 대규모 촛불시위와 같은 사회적 움직임이 예상되며, 통신과 관련된 기업 및 촛불 제조와 연관된 산업에 관심이 모이고 있습니다. --- ## 2. 기업 및 관련주 대규모 시위 및 관련 활동으로 인해 통신, 미디어, 그리고 촛불 제조와 관련된 기업들이 단기적인 수혜를 볼 것으로 예상됩니다. ### 2-1. 통신 관련주 #### 1. **KT (030200) [약 12조 원]** - **주요 산업:** 통신 - **관련주 근거:** 시위 생중계 및 대규모 통신 트래픽 증가로 매출 증대 가능성 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code=030200) #### 2. **SK텔레콤 (017670) [약 12조 원]** - **주요 산업:** 통신 - **관련주 근거:** 대규모 데이터 사용 증가로 인한 수익 상승 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code=017670) #### 3. **LG유플러스 (KOSPI, 032640) [약 4.9조 원]** - **주요 산업:** 통신 - **관련주 근거:** 촛불시위로 인한 데이터 및 음성 서비스 사용 증가 예상 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code=032640) --- ### 2-2. 방송 관련주 #### 1. **SBS (034120) [약 2,924억 원]** - **주요 산업:** 방송 및 미디어 콘텐츠 제작 - **관련주 근거:** 시위 관련 특집 방송 및 실시간 보도에 따른 광고 수익 증가 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code...
키움 OPEN API MFC 개발 (1)
* 키움 API 개발 - visual studio 2019 , MFC * Visual Studio Set - 새 프로젝트 만들기 / MFC 검색 - 다음 이후, MFC 설정에서 어플리케이션 종류 변경 (대화 상자 기반) * 기본 적용 Flow ( https://www.kiwoom.com/nkw.templateFrameSet.do?m=m1408000000 ) = 우선 생략하고, Step 2 설치 = Step 3 자료실/ KhOpenApiTest_2.71.zip 다운로드 * Step 2 설치 후, 설치 경로의 OpenAPI 디렉토리 찾기 1. 파일 찾기 2. KHOpenAPI.ocx 를 프로젝트 소스에 복사 * Step 3 자료실/다운로드 1. khOpenApiTest_2.71.zip 다운/압축 풀고, 2. KHOpenAPI.cpp/h KHOpenAPICtrl.cpp/h 프로젝트 소스에 복사 * 내부 소스에 다음추가 header에 class 생성 cpp에 다음 소스 추가 * 리소스 뷰 > IDD_TRADINGAPP_DIALOG 1. 확인 우클릭 > Active X 컨트롤 삽입 2. KHOpenAPI Control 적용 하면 위 화면처럼 적용 이후 실행 시 다음 화면 이후 매수/매도 적용
좋아요!!!
답글삭제