[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조 원] - **주요 산업**: 식품 제조 및 발효제품 - **관련주 근거**: 계엄...
한국 핵무장 논의와 방위산업 관련주: 핵무기 개발 과정과 유망 종목 분석
한국의 독자적 핵무장 논의가 주요 이슈로 떠오르며 방위산업 관련 주식들이 주목받고 있습니다. 특히, 핵무기 및 방어 관련 기술력을 보유한 기업들이 관심을 끌고 있어 투자자들에게 큰 잠재적 수혜가 예상됩니다. 트럼프 전 미국 대통령의 재집권 가능성 등 외교적 변화는 이러한 방위산업 관련주를 더욱 부각시키고 있습니다. --- ### 핵무기 생산과정 요약 #### **핵연료 확보** : 고농축 우라늄-235 또는 플루토늄-239와 같은 핵분열 물질을 확보하는 과정입니다. - **우라늄 농축**: 우라늄-235의 비율을 약 90% 이상으로 높이는 과정입니다. - **플루토늄 생산**: 원자로에서 우라늄-238을 중성자로 포획하여 플루토늄을 생성하고 이를 화학적으로 분리합니다. #### **폭발 장치 개발** : 확보한 핵연료를 폭발할 수 있도록 설계된 장치입니다. - **충돌 방식 (Gun-type)**: 고농축 우라늄을 이용해 두 덩어리를 빠르게 결합시켜 핵분열을 유도합니다. - **내부 압축 방식 (Implosion-type)**: 고폭압력으로 플루토늄을 압축하여 임계 질량을 초과하도록 합니다. ####. **무기화 및 배치** - 폭발 장치를 무기 형태로 조립하여 배치 가능한 상태로 만드는 과정입니다. 미사일, 폭격기 등에 탑재될 수 있도록 설계합니다. --- ### 핵심적인 부분 가장 중요한 부분은 **핵연료 확보**와 **폭발 장치 개발**입니다. - **핵연료 확보**: 핵분열 물질 확보가 핵무기 개발의 필수 조건입니다. 우라늄 농축과 플루토늄 생산은 고도의 기술력을 요구하며, 보안과 국제적인 감시가 강화된 부분입니다. - **폭발 장치 개발**: 핵연료가 있어도 이를 효과적으로 폭발시키는 장치가 없다면 무기화가 불가능합니다. 압축 방식 등 폭발 장치 개발 기술이 핵무기의 폭발력과 신뢰성을 좌우하는 중요한 요소입니다. --- ### 핵연료 확보 관련 기업 - **한전원자력연료 (KEPCO NF)** :...
[로스트아크] 제작 효율 최적화 위한 영지 세팅
### 1. 대성공 확률 증가 vs. 제작 수수료 절감 - **대성공 확률 증가**: 대성공 확률이 2% 증가해도 실제 효과는 크지 않습니다. 예를 들어, 기본 대성공 확률 5%에 2% 증가를 적용해도 실질적인 효과는 0.1% 증가에 불과합니다. - **제작 수수료 절감**: 제작 수수료를 2% 절감할 경우, 제작할 때마다 발생하는 골드 비용을 직접적으로 줄일 수 있어 비용 절약 효과가 훨씬 큽니다. - 결과적으로, 제작 수수료 절감이 대성공 확률 증가보다 약 10배 더 많은 이득을 제공합니다. 따라서 대성공 확률보다는 수수료 절감에 집중하는 것이 권장됩니다. --- ### 2. 효율적인 영지 세팅을 위한 이득 극대화 세팅 - 영지 내 필수 세팅 아이템으로 "곡예사의 대기실," "찬란한 소원 나무," "여신의 가호"가 추천됩니다. - **곡예사의 대기실**: 마리샵에서 블루 크리스탈로 구매할 수 있으며, 기본적인 제작 효율을 높이는 데 필수 아이템입니다. - **찬란한 소원 나무**: 수수료 절감을 제공하여 제작 비용을 절감하는 효과가 있어 이득 극대화에 도움이 됩니다. - **여신의 가호**: 미술품 42개를 모아 획득할 수 있으며, 추가적인 제작 효율을 제공합니다. 여유가 있다면 필수로 장착하는 것이 좋습니다. - 여신의 가호 대신, **곡예사의 무기 진열대**를 구매해 사용할 수도 있으며, 경제적인 선택지로 활용할 수 있습니다. --- ### 3. 의상 세팅 (선택적 적용) - 특정 의상을 착용하면 제작 효율이 약간 증가하지만, 최적의 의상 옵션은 없기 때문에 필수는 아닙니다. 크리스탈 비용이 부담스러울 경우 생략 가능하며, 다른 세팅을 우선적으로 강화하는 것이 좋습니다. - **드레스룸 이용**: 크리스탈을 사용하여 드레스룸에서 특정 NPC와의 호감도로 얻을 수 있는 의상을 구매할 수 있습니다. - **추천 의상**: 페...
좋아요!!!
답글삭제