您好,登錄后才能下訂單哦!
有一些,經典的對文件的操作。
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++);//展示需要的那個結點
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。