找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 6514|回復: 0
打印 上一主題 下一主題
收起左側

c語言中的鏈表-用結構體和指針構造鏈表

[復制鏈接]
跳轉到指定樓層
樓主
ID:73477 發(fā)表于 2015-2-10 17:42 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
/************************************************************************************

用結構體和指針構造鏈表:
    HEAD = p = (struct student *) malloc(LEN);的語句是用LEN讀出將要開辟的新
單元所需的空間,然后由malloc();開辟一個新的空間并將新的空間的首地址返回。
注意:malloc函數(shù)返回的地址(指針)是(void)類型的,即不指向一個特定的類
型的對象,因此,對其返回值進行強制類型轉換,即(struct student *)malloc(LEN),
使它能指向struct student 類型的數(shù)據(jù)。

**************************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>  //用malloc函數(shù)開辟新單元時需用此頭文件

#define    LEN     sizeof(struct student) //LEN代表struct student類型數(shù)據(jù)的長度

struct student       //聲明struct student類型
{
    int num;
    float score;
    struct student *NEXT;  //指針變量HEAD和p
};

int main()
{
    int i,n;
    struct student *HEAD,*p,*q;  //定義struct student類型的指針變量
    printf("Please Input:\t");
    scanf("%d",&n);              //輸入鏈表的長度
    HEAD = p = (struct student *) malloc(LEN);  //開辟一個新單元并讓p和HEAD指向它
    scanf("%d%f",&p->num,&p->score);            //輸入第一個結點的數(shù)據(jù)
    for(i=1;i<n;i++)                            //當鏈表的長度達到指定的長度時結束
    {
        q = (struct student *) malloc(LEN);     //開辟第i個新單元,并讓q指向它
        scanf("%d%f",&q->num,&q->score);        //輸入第i個結點的數(shù)據(jù)
        p->NEXT = q;                            //使第i-1個結點的成員NEXT指向第i個結點
        p = q;                                  //使p指向第i個結點
    }
    p->NEXT = NULL;                             //使最后個結點的NEXT成員不指向任何結點
    printf("The information:\n");
    for(p=HEAD;p!=NULL;)                        //當p不指向任何一個結點時結束循環(huán)
    {
        printf("%d\t%.2f\n",p->num,p->score);   //輸出當前結點的數(shù)據(jù)
        p = p->NEXT;                            //使p指向下一個結點
    }
    return 0;
}





分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表