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