習題3 5 求鍊錶的倒數第m個元素 20分

2021-10-07 15:37:55 字數 1879 閱讀 7020

elementtype find

( list l,

int m )

;

其中list結構定義如下:

typedef

struct node *ptrtonode;

struct node

;typedef ptrtonode list;

/* 定義單鏈表型別 */

l是給定的帶頭結點的單鏈表;函式find要將l的倒數第m個元素返回,並不改變原鍊錶。如果這樣的元素不存在,則返回乙個錯誤標誌error。

#include

#include

#define error -1

typedef

int elementtype;

typedef

struct node *ptrtonode;

struct node

;typedef ptrtonode list;

list read()

;/* 細節在此不表 */

void

print

( list l )

;/* 細節在此不表 */

elementtype find

( list l,

int m )

;int

main()

/* 你的**將被嵌在這裡 */

輸入樣例:

51 2 4 5 6

3輸出樣例:

41 2 4 5 6

elementtype find

( list l,

int m )

list q = l;

while

(p)return q->data;

}

#include

#include

#define error -1

typedef

int elementtype;

typedef

struct node *ptrtonode;

struct node

;typedef ptrtonode list;

list read

(void);

void

print

(list l)

;void

delete

(list l)

;elementtype find

(list l,

int m)

;int

main

(void

)list read

(void

)int data =0;

scanf

("%d"

,&data)

; head->data = data;

head->next =

null

; list record = head;

while

(--num)

return head;

}void

delete

(list l)

}void

print

(list l)

printf

("\n");

}elementtype find

(list l,

int m)

list q = l;

while

(p)return q->data;

}

習題3 5 求鍊錶的倒數第m個元素 20分

請設計時間和空間上都盡可能高效的演算法,在不改變鍊錶的前提下,求鏈式儲存的線性表的倒數第m 0 個元素。elementtype find list l,int m 其中list結構定義如下 typedef struct node ptrtonode struct node typedef ptrto...

求鍊錶的倒數第m個元素

習題3.5 求鍊錶的倒數第m個元素 20分 請設計時間和空間上都盡可能高效的演算法,在不改變鍊錶的前提下,求鏈式儲存的線性表的倒數第m 0 0 個元素。elementtype find list l,int m 其中list結構定義如下 typedef struct node ptrtonode s...

求鍊錶的倒數第m個元素

方法一 先遍歷一次鍊錶,得到長度n,在從頭遍歷找到第n m 1個元素。elementtype find list l,int m if m n m的位置不合法 int i 1 p l for i n m 1 i p p next return p data 方法二 定義兩個指標變數p1,p2,在初始...