C 언어는 비순환 쌍사슬표 노드의 삭제를 실현한다(선두 결점 끝 결점)
1415 단어 양방향 체인 테이블
핵심 코드는 다음과 같습니다.
// pos
int DeletePosList(Node *pHead,Node *pTail,int pos){
int i = 1;
Node *pMove;
pMove = pHead->next;
while (pMove != pTail) {
if (i == pos) {
pMove->prior->next = pMove->next;
pMove->next->prior = pMove->prior;
free(pMove);
pMove = NULL;
printf("%s , pos=%d
",__FUNCTION__,pos);
return 1;
}
i++;
pMove = pMove->next;
}
printf("%s , pos=%d
",__FUNCTION__,pos);
return 0;
}
// x ,
int DeleteValueList(Node *pHead,Node *pTail,int x){
Node *pMove;
pMove = pHead->next;
while (pMove != pTail) {
if (pMove->element == x) {
pMove->prior->next = pMove->next;
pMove->next->prior = pMove->prior;
free(pMove);
pMove = NULL;
printf("%s , x=%d
",__FUNCTION__,x);
return 1;
}
pMove = pMove->next;
}
printf("%s , x
",__FUNCTION__);
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
양방향 체인 시계를 만드는 함정!!다음은 양방향 체인 테이블을 만드는 함수입니다. 치명적인 오류를 알 수 있습니까? 답: 23줄에서 헤드헤드헤드헤드에 새로운 값이 부여된 후에 헤드->before는 원래의 헤드 결점을 가리키는데 원래의 헤드 결점은 데...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.