标签:链表
有一些,经典的对文件的操作。
fin = fopen ( argv[1], "rt" );//获取文件的指针
if ( fin == NULL )//判断是否为空
{
fprintf ( stderr, "Cannot open/find %s\n", argv[2] );
exit ( EXIT_FAILURE );
}
/* Create and initialize the linked list to empty */
CreateList();
/*--- main loop ---*/
while ( ! feof ( fin ))//判读文件是否读完
{
/* read a record consisting of a line of text */
if ( fgets ( buffer, 127, fin ) == NULL )
break;
char *p;
char *name;
char* a;
p = strtok(buffer, " ,");//截取字符串,成一段一段的。
strcpy(n->StuId, p);//将一个字符串指针的内容存储到一个字符数组中
name = strtok(NULL, " ,");
strcpy(n->Name, name);
a = strtok(NULL, " ,");
n->age = atoi(a);//转换字符型为整形
n->Next = NULL;///你个傻逼,你不看看到底实际空间是谁的。!!!!!这个一定要设置,否则判断最后是否为空没法判断!!!
printf("===============================\n");
printf("%20s,%10s,%d\n",n->StuId, n->Name, n->age);
printf("===============================\n");
/* add the node to the list */
if ( AddNodeAscend ( n ) == 0 ) //如果没加上这个节点。
{
fprintf ( stderr, "Error adding node. Aborting\n" );
exit ( EXIT_FAILURE );
}
}
while (scanf("%s", cmd) != EOF){
if (cmd[0] == ‘H‘ || cmd[0] == ‘h‘)
{
printf("例如:\n 查找第一个结点:P0\n 删除第一个节点:D0\n 在位置一处插入节点:I1 SA17225130 马云 34 退出程序:q|Q\n\n");
}
else if (cmd[0] == ‘P‘){
int n = atoi(strdup(cmd + 1));//将cmd[1]以及后面所有字符串提取出来转成整形
ShowOneNode(n++);//展示需要的那个结点
}
本文出自 “姑苏城” 博客,请务必保留此出处http://ji123.blog.51cto.com/11333309/1975538
标签:链表
原文地址:http://ji123.blog.51cto.com/11333309/1975538