링크드 리스트 왜이런지좀 고쳐 주세요...
늘솔길
우선 질문이 많아서 죄송합니다.ㅠㅜ
혼자 해결해 보려 했으나..역부족이라
도움을 청합니다... 부디 ..;;
/////////////////////////////
이코드는 저장된 레코드 중에서 하나의 레코드를 삭제하는 함수입니다
////////////////
void DeleteOneData(char *_Data, int &S_Type)
{
int Select;
int No=1;
coutendl; cout┌[ 삭제할 데이타 번호 입력 ]────────‥endl;
cout└ \No\ : ;
cinSelect;
Node *PrevNode = Head;
Node *CurNode = Head-Next;
Node *DelNode;
if(S_Type==1) { while(CurNode!=Rear){
if(strstr(CurNode-Name,_Data)) {
if(Select==No){
No++;
PrevNode-Next = CurNode-Next;
DelNode = CurNode;
CurNode = PrevNode-Next;
delete []DelNode;
break;}
else {No++;
PrevNode = PrevNode-Next;
CurNode = CurNode-Next;} }
else { PrevNode = PrevNode-Next; CurNode = CurNode-Next; } } }
else if(S_Type==2) {
while(CurNode!=Rear){
if(strstr(CurNode-Phone,_Data)) {
if(Select==No){
No++;
PrevNode-Next = CurNode-Next;
DelNode = CurNode;
CurNode = PrevNode-Next;
delete []DelNode; break;}
else {No++; PrevNode = PrevNode-Next; CurNode = CurNode-Next;} }
else { PrevNode = PrevNode-Next; CurNode = CurNode-Next; } } }
else if(S_Type==3) {
while(CurNode!=Rear){
if(strstr(CurNode-Adress,_Data)) {
if(Select==No){
No++;
PrevNode-Next = CurNode-Next;
DelNode = CurNode;
CurNode = PrevNode-Next;
delete []DelNode; break;}
else {No++; PrevNode = PrevNode-Next; CurNode = CurNode-Next;} }
else { PrevNode = PrevNode-Next; CurNode = CurNode-Next; } } }
coutendl; if(No==++Select) { cout :: 정상적으로 삭제 되었습니다. endl; }
else { cout :: 삭제 실패...!! endl; } }
////////////////////
그런데 반복되는 부분이 많다보니 함수가 너무 길어지더라구요
그래서 삭제하는 부분만 따로 빼서 함수로 만들었느데 말이지요
예를들어
if(S_Type==1) {
while(CurNode!=Rear){
if(strstr(CurNode-Name,_Data)) {
if(Select==No){
No++;
PrevNode-Next = CurNode-Next;
DelNode = CurNode;
CurNode = PrevNode-Next;
delete []DelNode;break;}
else {No++; PrevNode = PrevNode-Next; CurNode = CurNode-Next;}
}
else { PrevNode = PrevNode-Next; CurNode = CurNode-Next; } } }
이부분을
if(S_Type==1) {
while(CurNode!=Rear){
if(strstr(CurNode-Name,_Data)) {
if(Select==No){++No; DeleteData(CurNode, PrevNode); break;}
else {No++; PrevNode = PrevNode-Next; CurNode = CurNode-Next;} }
else { PrevNode = PrevNode-Next; CurNode = CurNode-Next; } } }
void DeleteData(Node *CurNode, Node *PrevNode)
{
Node *DelNode;
PrevNode-Next = CurNode-Next;
DelNode = CurNode;
CurNode = PrevNode-Next;
delete []DelNode;
}
이렇게 바꾸려구요..
나머지도 저 부분이 함수호출로 대체 될건데요
문제는 원래 함수로 따로 분리하기전에는 문제 없이 잘 돌아갑니다
&nbP
그런데 이렇게 함수로 따로 처리를 해주고 나니
안되더라구요-_- 정상적이지 않게 종료가 되요..
문법상으론 똑같은거 같은데 왜 안되죠?
어떻게 해야 함수처리 가능한지 알려주세요.ㅠㅜ
-
희1미햬
C++ Q&A 게시판에서 C언어 Q&A 게시판으로 이동시켰습니다.
-
봄해
DeleteData()를 호출한 곳에 있는 CurNode 변수와 DeleteData()함수 내의 CurNode 변수는 서로 다르기 때문입니다.
함수의 인자를 이중포인터로 한 뒤에 적절히 수정하여 실행해보세요.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695327 | 안녕하세요 제가 이번에 좀 큰 프로그램을.. | 악당 | 2025-05-19 |
2695295 | mutex동기화의 thread기반 채팅 서버소스 질문입니다 | 그루터기 | 2025-05-19 |
2695270 | 질문이요..swap 관한겁니다..ㅠㅠ (3) | 콩알녀 | 2025-05-19 |
2695244 | 노땅초보궁금한게 하나 있는데요..반복문(while문)초보자질문 (6) | 큰꽃늘 | 2025-05-18 |
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |
2694900 | dequeue 에서 리턴값 프린트 방법알려주세요 오늘 12시까지 대화방에 있습니다 도와주세요 | 미투리 | 2025-05-15 |
2694854 | 절대값을 구할때 (2) | 그녀는귀여웠다 | 2025-05-15 |
2694827 | 이제 어떻게 공부해야할지 모르겠네요 | 새얀 | 2025-05-14 |
2694778 | 순열 계산요. | 맛조이 | 2025-05-14 |
2694754 | ShowWindow 함수를 이용하려 하는데 질문있습니다. (2) | 파도 | 2025-05-14 |
2694731 | 리눅스 커널의 시작점 질문 | 미르 | 2025-05-13 |
2694702 | 이거 뭐가문제인가요 코드수정좀 (3) | 맑은 | 2025-05-13 |
2694675 | C언어 후위표기를 중위표기로 | 앨런 | 2025-05-13 |