c語言結構體鏈表
㈠ C語言程序,怎麼在結構體鏈表中插入或者刪除某個結構體
沒學過數據結構?那你們老師在幹嘛?數據結構不應該是和語言同步進行的嗎?
struct A //這就是個結構體,包含數據域和指針域
{
int a;//數據域,可以是任何類百型的。
char b;//數據域
A *p;//指針域,就是struct A類型。
};鏈表,一般是動態的。你要靜態的就不用malloc分配就行了。定義N個struct
A就行了。
struct A a1;
struct A a2;
struct A a3;
struct A a4;
//a1作為第一個節點
a1->next = a2;
a2->next = a3;
a3->next = a4;
a4->next = NULL;
//插入,在a2後面插入a5
struct A a5;
a5->next = a2->next;
a2->next = a5;//注意指針的賦值順序。雖然全部是度靜態的問題不大。動態分配的時候不仔細會造成斷鏈,內存溢出。
//刪除a5
a2->next = a5->next;//靜態不存在釋放的問題,動態申請的請釋放a5;
㈡ C語言中,結構體與鏈表是什麼關系
可以用結構體來實現鏈表啊。結構體相當於一種數據類型。鏈表是數據結構的一種,可以用結構體來實現鏈表。
希望採納
㈢ C語言怎麼存鏈表形式的結構體文件
看你的代碼是每次寫入一個節點到文件,但是fwrite(p,sizeof(struct room),NUM,fp);這句是每次寫入NUM大小的一個room數組,把NUM改成1:
fwrite(p,sizeof(struct room),1,fp); //每次寫入一個節點
㈣ C語言利用結構體變數構成的單項鏈表怎麼排序
首先定義一個結構體,如:
struct
studentData
{
char
sno[4];
/*學號*/
char
sname[21];
/*姓名*/
int
age;
/*年齡*/
int
score[5];
/*五門成績*/
};
再定義構成單鏈表的結點:struct
student
{
/*數據域*/
struct
studentData
info;
struct
student
*next;/*指針域*/
};
下面是選擇排序:void
OrderBySnoAsc(){
//以學號按升序排序
struct
student
*p,*q,*min;
struct
studentData
temp;
//交換時用到的臨時變數
for(p=head;p
!=
NULL;p=p->next){
min=p;
for(q=p->next;q
!=
NULL;q=q->next)
if(strcmp(min->info.sno,q->info.sno)>0)
min=q;
if(min!=p){
temp=min->info;
min->info
=p->info;
p->info=temp;
}
}
}
以下是冒泡排序:void
OrderBySnoAsc(){
//以學號按升序排序
struct
student
*p,*q;
struct
studentData
temp;
//交換時用到的臨時變數
for(p=head;p!=NULL;p=p->next)
{
for(q=head;q->next!=NULL;q=q->next)
{
if(strcmp(q->info.sno,q->next->info.sno)>0)//相鄰的兩個之間比較
{
temp=q->info;
q->info
=q->next->info;
q->next->info=temp;
}
}
}
}
㈤ C語言中怎樣用鏈表保存結構體數據(動態數據結構)
鏈表有多種形式,如:單向鏈表,雙向鏈表,單向循環鏈表,雙向循環鏈表。將鏈表結構定義為list_t,則該類型中一定(至少)存在一個指向下一節點的指針list_t
*next;除了這個指針,list_t
中可以包含其它類型的數據,包括結構體變數。比如:typedef
struct
{
struct
usr_struct
data;
list_t
*next;
}
list_t;
㈥ C語言中的鏈表怎麼理解
鏈表是相同類型的若干個結構體用其自身攜帶的指針按照一定順序串聯成的一個鏈。
舉個簡單例子進行類比:
struct node{
int a;
struct node *next;
};
把這個鏈表節點的結構體struct node看作是人,結構體內的next指針看作是人的一隻手,這只手只能用於指向人(別人或自己)。
如果有多個人排成一排,每個人都舉起右手指向右邊的人,就形成一個人組成的鏈表。
㈦ C語言結構體鏈表
struct link:叫link 的結構。
結構就是沒有特有方法/函數的類。僅用來放數據。
struct link *P; link類型的指針P;
指針可指向任意同類型的數據或數組。本身不分配實體空間。僅地址。
char ch;字元型的叫ch的屬性。
a;同時製造link類型的 a實體。