尾插法建立链表的一些操作程序运行就会显示错误,就大神指教

MaxCentaur 2013-11-28 10:43:36
/*
* tail_create_sort_invertion.c
* 尾插法建立链表并进行排序(大到小),倒置;
*/
#include <stdio.h>
#include <stdlib.h>
typedef char datatype ;
//节点的描述
typedef struct node {
datatype data; //数据域
struct node *next; //指针域
}listnode,*linklist;
linklist tail_createlist(linklist list,int * n); //函数声明
linklist print(linklist list,int n);
linklist sort(linklist list,int n);
linklist invertion(linklist list,int n );
main(void)
{
int count ; //节点数
count = 0;
linklist LIST;
LIST = NULL;
LIST = tail_createlist(LIST,&count);//这样要返回值,因为指针作为函数参数无法改变指针的指向,必须用返回值了
print(LIST,count);
LIST = sort(LIST,count);
print(LIST,count);
LIST = invertion(LIST,count);
printf("\n");
return 0;
}
linklist tail_createlist(linklist list,int * n){
list = (linklist)malloc(sizeof(listnode));//头结点分配空间
//变量声明
linklist p,r; //r为尾指针
r =list = NULL;
datatype ch;
while ((ch = getchar()) != '\n'){
p = (linklist)malloc(sizeof(listnode));
++ *n;
p->data = ch;
r->next = p;
r = p;
}
r->next = NULL;
return (list);
}
linklist print(linklist list,int n){
while (list->next != NULL){
printf("%c",list->next->data);
list = list->next;
}
printf("\n");
printf("%d\n",n);
return 0 ;
}
linklist sort(linklist list,int n){
//用冒泡法做一个循环
linklist sign;
sign = list;
int i , j ;
datatype exchange;

for(i = 1;i<= n;i++){
list = sign;
for(j = 1;j<= n-i;j++){
if((list->next->data) < (list->next->next->data)){
exchange = list->next->next->data;
list->next->next->data = list->next->data;
list->next->data = exchange;
}
list = list->next;
}
}

return (list);
}
linklist invertion(linklist list,int n){
int i , j;
linklist sign;
sign = list;
for(i = 1;i <= n; i++){
list = sign;
for(j = 1; j <= n - i;j++){
list = list->next;
}
printf("%c",list->next->data);

}
return (list);
}
...全文
134 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
w195438178 2013-11-29
  • 打赏
  • 举报
回复
你建立的链表有问题,改成这样: linklist tail_createlist(linklist list,int * n){ list = (linklist)malloc(sizeof(listnode));//头结点分配空间 //变量声明 linklist p,r; //r为尾指针 r = list; //list = NULL; datatype ch; while ((ch = getchar()) != '\n'){ p = (linklist)malloc(sizeof(listnode)); ++ *n; p->data = ch; r->next = p; r = p; } r->next = NULL; return (list); }
w195438178 2013-11-29
  • 打赏
  • 举报
回复
见你的新帖: 附上答复 关于尾链 /* * 尾插法建立链表并进行排序(大到小),倒置; */ linklist tail_createlist(linklist list,int * n){ list = (linklist)malloc(sizeof(listnode));//头结点分配空间 //变量声明 linklist p,r; //r为尾指针 r =list = NULL; datatype ch; while ((ch = getchar()) != '\n'){ p = (linklist)malloc(sizeof(listnode)); ++ *n; p->data = ch; r->next = p; r = p; } r->next = NULL; return (list); } 这个函数的这句话 r =list = NULL; 改成: r = list; list = NULL;
xyzinfernity 2013-11-29
  • 打赏
  • 举报
回复
list = (linklist)malloc(sizeof(listnode));//头结点分配空间
	//变量声明
	linklist p,r;	//r为尾指针
	r = p = NULL;
之前给list分配了空间后面又为什么要赋值NULL呢?
主要特性Java 语言是简单的:Java 语言的语法与 C 语言和 C++ 语言很接近,使得大多数程序员很容易学习和使用。另一方面,Java 丢弃了 C++ 中很少使用的、很难理解的、令人迷惑的那些特性,如操作符重载、多继承、自动的强制类型转换。特别地,Java 语言不使用指针,而是引用。并提供了自动分配和回收内存空间,使得程序员不必为内存管理而担忧。Java 语言是面向对象的:Java 语言提供类、接口和继承等面向对象的特性,为了简单起见,只支持类之间的单继承,但支持接口之间的多继承,并支持类与接口之间的实现机制(关键字为 implements)。Java 语言全面支持动态绑定,而 C++语言只对虚函数使用动态绑定。总之,Java语言是一个纯的面向对象程序设计语言。Java语言是分布式的:Java 语言支持 Internet 应用的开发,在基本的 Java 应用编程接口中有一个网络应用编程接口(java net),它提供了用于网络应用编程的类库,包括 URL、URLConnection、Socket、ServerSocket 等。Java 的 RMI(远程方法激活)机制也是开发分布式应用的重要手段。Java 语言是健壮的:Java 的强类型机制、异常处理、垃圾的自动收集等是 Java 程序健壮性的重要保证。对指针的丢弃是 Java 的明智选择。Java 的安全检查机制使得 Java 更具健壮性。Java语言是安全的:Java通常被用在网络环境中,为此,Java 提供了一个安全机制以防恶意代码的攻击。除了Java 语言具有的许多安全特性以外,Java 对通过网络下载的类具有一个安全防范机制(类 ClassLoader),如分配不同的名字空间以防替代本地的同名类、字节代码检查,并提供安全管理机制(类 SecurityManager)让 Java 应用设置安全哨兵。Java 语言是体系结构中立的:Java 程序(后缀为 java 的文件)在 Java 平台上被编译为体系结构中立的字节码格式(后缀为 class 的文件),然后可以在实现这个 Java 平台的任何系统中运行。这种途径适合于异构的网络环境和软件的分发。Java 语言是可移植的:这种可移植性来源于体系结构中立性,另外,Java 还严格规定了各个基本数据类型的长度。Java 系统本身也具有很强的可移植性,Java 编译器是用 Java 实现的,Java 的运行环境是用 ANSI C 实现的。Java 语言是解释型的:如前所述,Java 程序在 Java 平台上被编译为字节码格式,然后可以在实现这个 Java 平台的任何系统中运行。在运行时,Java 平台中的 Java 解释器对这些字节码进行解释执行,执行过程中需要的类在联接阶段被载入到运行环境中。Java 是高性能的:与那些解释型的高级脚本语言相比,Java 的确是高性能的。事实上,Java 的运行速度随着 JIT(Just-In-Time)编译器技术的发展越来越接近于 C++。Java 语言是多线程的:在 Java 语言中,线程是一种特殊的对象,它必须由 Thread 类或其子(孙)类来创建。通常有两种方法来创建线程:其一,使用型构为 Thread(Runnable) 的构造子类将一个实现了 Runnable 接口的对象包装成一个线程,其二,从 Thread 类派生出子类并重写 run 方法,使用该子类创建的对象即为线程。值得注意的是 Thread 类已经实现了 Runnable 接口,因此,任何一个线程均有它的 run 方法,而 run 方法中包含了线程所要运行的代码。线程的活动由一组方法来控制。Java 语言支持多个线程的同时执行,并提供多线程之间的同步机制(关键字为 synchronized)。Java 语言是动态的:Java 语言的设计目标之一是适应于动态变化的环境。Java 程序需要的类能够动态地被载入到运行环境,也可以通过网络来载入所需要的类。这也有利于软件的升级。另外,Java 中的类有一个运行时刻的表示,能进行运行时刻的类型检查。

69,369

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧