为什么程序只能输出未插入数据前的链表

C语言 码拜 9年前 (2015-11-12) 915次浏览
为什么程序只能输出未插入数据前的链表

#include <stdio.h>
#include <stdlib.h>
typedef struct node ListNode ;
typedef struct node* PtrList ;
struct node
{
	int data ;
	struct node* next ;
} ;
PtrList CreateList( int N )
{
	int i ;
	int Data ;
	PtrList head ;
	PtrList PtrCurrent , PtrPrevious ;
	//建立一个表头为空结点的链表
	//链表的初始化
   
	PtrCurrent = ( PtrList )malloc( sizeof(ListNode) ) ;
	PtrCurrent->next = NULL ;
	head = PtrCurrent ;

	for( i=0 ; i<N ; i++ )
	{
		scanf("%d" , &Data) ;
		PtrPrevious = PtrCurrent ;
		PtrCurrent = ( PtrList )malloc( sizeof(ListNode) ) ;
		PtrCurrent->data = Data ;
		PtrPrevious->next = PtrCurrent ;
		PtrCurrent->next = NULL ;
	}
	return head ;
}
void  InsertList( PtrList List )
{
	int Data ;
	PtrList PrePosition ; //插入位置的前一个位置
    PtrList InsertNode ;
	scanf("%d" , &Data ) ;
	InsertNode = ( PtrList )malloc(sizeof(ListNode) ) ;
	InsertNode->data = Data ;
	InsertNode->next = NULL ;

	PrePosition = List ;
	while((InsertNode->data) > (PrePosition->next->data) && PrePosition->next!=NULL )
	{
		PrePosition = PrePosition->next ;
	}
	InsertNode->next = PrePosition->next;
	PrePosition = InsertNode ;

}
void PrintfList( PtrList head )
{
	PtrList p ;
	p = head->next ;
	while( p )
	{
		printf( "%d " , p->data ) ;
		p=p->next ;
	}
	printf("\n") ;
}
int main()
{
	int N ;
	PtrList List ;
	scanf("%d" , &N) ;

	List = CreateList( N ) ;
	PrintfList( List ) ;
 	InsertList( List ) ;
	PrintfList( List ) ;
}
解决方案:20分
60行的

PrePosition = InsertNode ;

改为

PrePosition->next = InsertNode ;

CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明为什么程序只能输出未插入数据前的链表
喜欢 (0)
[1034331897@qq.com]
分享 (0)