#include <stdio.h> #include <stdlib.h> #include <string.h> #define NAME_SIZE 15 // 記錄好友資料的結構 struct friendData { char name[NAME_SIZE]; int age; int sex; int relation; }; // 暫存在記憶體中的資料結構:鏈結串列 struct linkedListNode { struct friendData data; struct linkedListNode *nextPtr; }; typedef struct linkedListNode LinkedListNode; int main(void) { LinkedListNode *startPtr, *newPtr, *currentPtr; char fname[NAME_SIZE]; int i, fage, fsex, frelation; i = 0; startPtr = NULL; while (i < 5) { // 向作業系統要求新的記憶體空間 newPtr = malloc(sizeof(LinkedListNode)); // 依序輸入好友資料 printf("\n好友暱稱: "); scanf("%s", fname); printf("好友年齡: "); scanf("%d", &fage); printf("好友性別 - 0.女 1.男: "); scanf("%d", &fsex); printf("好友關係 - 0.家人 1.同學 2.朋友: "); scanf("%d", &frelation); // 將好友資料拷貝到剛才取得的記憶體空間之中 strcpy(newPtr->data.name, fname); newPtr->data.age = fage; newPtr->data.sex = fsex; newPtr->data.relation = frelation; newPtr->nextPtr = NULL; // 將資料加入鏈結串列 if (startPtr == NULL) { startPtr = newPtr; } else { currentPtr = startPtr; while (currentPtr != NULL) { if (currentPtr->nextPtr == NULL) { currentPtr->nextPtr = newPtr; break; } currentPtr = currentPtr->nextPtr; } } i++; } // 依序由鏈結串獵取出資料,然後印在螢幕上 currentPtr = startPtr; printf("\n\n以下依好友名錄的儲存順序印出好友資料\n"); printf(" 好友暱稱 - 年 齡 - 性 別 - 關 係\n"); while (currentPtr != NULL) { printf("%10s - ", currentPtr->data.name); printf("%5d - ", currentPtr->data.age); printf("%5s - ", currentPtr->data.sex ? "男" : "女"); printf("%s \n", currentPtr->data.relation ? "同學或朋友" : "家人"); currentPtr = currentPtr->nextPtr; } return 0; } /* 《程式語言教學誌》的範例程式 http://pydoing.blogspot.com/ 檔名:listtest.c 功能:示範鏈結串列的使用 作者:張凱慶 時間:西元2010年7月 */
程式說明及編譯執行,請繼續參考
沒有留言:
張貼留言