더블 링크드 리스트
풍란
제가 공부하다가 만들긴만들었는데
일단 머 실행은 잘되긴 잘되는데
다른사람이랑 만든거랑 쫌 다른데
이렇게 만들어도 상관은 없나요???
#include stdio.h
#include stdlib.h
#include memory.h
typedef struct dataAAA{
int DataA;
} DBA,*PBA;
typedef struct datalink{
int index;
DBA dbainfo;
struct datalink* pNext;
struct datalink* pPre;
}DBLINK,*PDBLINK;
DBLINK *pHead;
DBLINK *pEnd;
void init();
void input();
void inputdata(DBLINK* pDa);
DBLINK *FindPre(int nNumber);
DBLINK *FindNext(int nNumber);
void show();
void deletedata();
int main()
{
int in = 0;
init();
while(1)
{
printf(1.입력 2.삭제 3.출력 4.종료 :);
scanf(%d,&in);
if(in==1) input();
else if(in==2) deletedata();
else if(in==3) show();
else if(in==4) break;
}
return 0;
}
void init()
{
pHead = (DBLINK*)malloc(sizeof(DBLINK));
pEnd = (DBLINK*)malloc(sizeof(DBLINK));
memset(pHead,0,sizeof(DBLINK));
memset(pEnd,0,sizeof(DBLINK));
pHead-pNext = pEnd;
pHead-pPre = pEnd;
pEnd-pNext = pHead;
pEnd-pPre = pHead;
}
void show()
{
DBLINK *imsi = NULL;
imsi = pHead-pNext;
if(imsi)
{
printf(번호 데이터\n);
while(imsi != pEnd)
{
printf(%3d,imsi-index);
printf(%7d\n,imsi-dbainfo.DataA);
imsi = imsi-pNext;
}
}
}
void input()
{
DBLINK *pFindPos = NULL;
DBLINK *pPrePos = NULL;
DBLINK *pData = (DBLINK*)malloc(sizeof(DBLINK));
memset(pData,0,sizeof(pData));
inputdata(pData);
pFindPos = FindNext(pData-index);
pPrePos = FindPre(pData-index);
pData-pNext = pFindPos;
pData-pPre = pPrePos;
pPrePos-pNext = pData;
pFindPos-pPre = pData;
}
void inputdata(DBLINK* pda)
{
printf(번호 : );
scanf(%d,&pda-index);
printf(데이터 :);
scanf(%d,&pda-dbainfo.DataA);
}
DBLINK *FindNext(int nNumber)
{
DBLINK *pTemp = pHead-pNext;
while(pTemp != pEnd)
{
if(pTemp-index nNumber) break;
else pTemp = pTemp-pNext;
}
return pTemp;
}
DBLINK *FindPre(int nNumber)
{
DBLINK *pTemp = pHead-pNext;
DBLINK *pTempPre = pHead;
while(pTemp != pEnd)
{
if(pTemp-index nNumber)
{
pTempPre = pTemp;
pTemp = pTemp-pNext;
}
else break;
}
return pTempPre;
}
void deletedata()
{
int in;
DBLINK *pTemp = pHead-pNext;
printf(삭제하실 데이터 번호 : );
scanf(%d,&in);
while(pTemp != pEnd)
{
if(pTemp-index == in)
{
pTemp-pNext-pPre = pTemp-pPre;
pTemp-pPre-pNext = pTemp-pNext;
break;
}
else pTemp = pTemp-pNext;
}
}
-
둘삥
가장 중요한 점은 프로그램은 에러가 없이 실행이 잘 되기만 하면 됩니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2698829 | 학점계산기 (7) | MyWay | 2025-06-20 |
2698782 | 기초적인 함수 질문이요ㅠㅠㅠㅠ | 내담 | 2025-06-20 |
2698749 | 프로그램 짜던 도중 패닉입니다...ㅜ | 파랑 | 2025-06-19 |
2698719 | 조건부컴파일 질문입니다.~ (2) | 큐트 | 2025-06-19 |
2698693 | 재귀 함수 에러 | 바닐라 | 2025-06-19 |
2698673 | 고민이있는데 들어좀주세요!! (1) | 초코맛캔디 | 2025-06-19 |
2698644 | 1부터 n까지의 합을 구하는데 엄청긴숫자의 합을 구할때는 어떻게 해야하나요? (4) | 슬우 | 2025-06-18 |
2698616 | 다른 함수로 안넘어갑니다..;;; | 도1도캣 | 2025-06-18 |
2698587 | 배열하다 막혀서... (3) | WhiteCat | 2025-06-18 |
2698559 | 문자열을 비우는방법 (2) | 하늘 | 2025-06-18 |
2698528 | 착하고 친절한 선생씌구해염~ㅋㅋ (4) | 옆집언니야 | 2025-06-17 |
2698502 | 자료구조 큐 | 캔서 | 2025-06-17 |
2698477 | 실행화면 배경문의요 | 선아 | 2025-06-17 |
2698430 | 변수의 값이 저장이 않되네요;; (4) | 피네 | 2025-06-16 |
2698404 | C#을 배울려고 하는데 C나 C++을 알아야 하나요 ?? (1) | 신당 | 2025-06-16 |
2698342 | 프로그램 질문점녀 (4) | 데빌의눈물 | 2025-06-16 |
2698318 | 파일 입출력 질문입니다~ (2) | 꽃 | 2025-06-15 |
2698291 | 문자 출력 함수 : putchar, fputc에 관하여. | 으뜸 | 2025-06-15 |
2698261 | 씨언어 (1) | 마리 | 2025-06-15 |
2698212 | 구조체, 포인터가 같이 들어간 프로그램 소스코드 있으신분? (4) | 그림자 | 2025-06-14 |