연결리스트 삭제 부분을 검색이 아닌, 맨 앞쪽것 또는 맨 뒤쪽것을 삭제하고 싶은데...
연와인
#include iostream
using namespace std;
//노드
struct Node
{
int data; //data멤버
Node* link; //다음 노드를 가리키는 포인터
};
class Linked_List
{
private:
Node *root; //시작 노드를 가리킴
Node *last; //마지막 노드를 가리킴(차례대로 연결하기 위해서)
public:
Linked_List() : root(NULL) {}
~Linked_List() {}
Node* create(int data);
void insert(int data);
void del(int data);
void print();
};
Node* Linked_List::create(int data)
{
Node *temp = new Node;
temp-data = data;
temp-link = NULL;
return temp;
}
//노드를 삽입
void Linked_List::insert(int data)
{
if (!root)
{
root = create(data);
last = root;
return ;
}
Node *temp = create(data);
last-link = temp;
last = last-link;
}
//노드를 삭제
void Linked_List::del(int data)
{
Node *prev = NULL; //삭제할 노드의 이전 노드를 가리킴
Node *temp = root; //root부터 검색
while (temp != NULL)
{
if (temp-data == data)
break;
prev = temp; //prev에 temp의 노드를 대입한후에.
temp = temp-link; //temp가 다음 노드를 가리케해야 됩니다
}
if (temp == NULL) //temp 가 NULL이라면 찾고자 하는 노드가 없죠.
{
cout 찾고자 하는 데이터가 없습니다\n;
return ;
}
//prev가 NULL이라면 위에서 초기화할때 NULL해줬으니 이 경우는 root가 되는경우입니다.
if (prev == NULL)
root = root-link;
else //root가 아니라면
prev-link = temp-link; //삭제하고자 하는 노드의 앞 노드랑 뒤 노드를 연결하면 됩니다.
delete temp; //삭제하고자 하는 노드의 메모리를 없애줍니다.
}
void Linked_List::print()
{
Node *temp = root;
while (temp != NULL)
{
cout temp-data;
temp = temp-link;
}
}
int main(void)
{
int data;
Linked_List list;
int select;
do
{
cout 입력(1), 삭제(2), 출력(3), 종료(4): ;
cin select;
switch (select)
{
case 1:
cout 삽입하고자 하는 수를 입력: ;
cin data;
list.insert(data);
break;
case 2:
cout 삭제하고자 하는 수를 입력: ;
cin data;
list.del(data);
break;
case 3:
cout 출력\n;
list.print();
cout endl;
break;
}
} while (select!= 4);
return 0;
}
여기서 삭제 부분을 검색이 아닌, 맨 앞쪽것 또는 맨 뒤쪽것을 삭제하고 싶은데...
제 생각에는 case 2 안에 del 데이타 값을 맨 앞쪽 데이터나 뒤쪽꺼 주면 될것 같은데;;;
머리로는 굴러가는데... 간만에..-_-;; 플그래밍이라.. 손을 못대겠네여~ ㅋ 선처 부탁드려요
-
바르고
ㅇㅇ...씨로 다시짯습니다 ㅋ
-
핫자두
이건 C++ 문법 같은데요. ^^
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692424 | 2차원배열 자료입력질문이요! (1) | 똘끼 | 2025-04-22 |
2692401 | 유닉스안에서 C언어를 이용한 명함 만들기 입니다; 이해안가는 부분이있네요 | 2gether | 2025-04-22 |
2692374 | 고수님들 댓글 마니부탁해요!!! (2) | 엄지 | 2025-04-22 |
2692343 | scnaf에 자꾸 선언을 참조하라는데;; (8) | 도래 | 2025-04-22 |
2692282 | 도스상에서 생성된 exe파일에 press~ 뜨게 하기 (4) | 회사원 | 2025-04-21 |
2692256 | scanf("%*c"); ㅠㅠ 고수님들 | 거북이 | 2025-04-21 |
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |