廣義表head和tail

2021-10-01 04:59:47 字數 1346 閱讀 8481

根據表頭、表尾的定義可知:

任何乙個非空廣義表的表頭是表中第乙個元素,它可以是原子,也可以是子表,

而其表尾必定是子表。

也就是說,廣義表的head操作,取出的元素是什麼,那麼結果就是什麼。

但是tail操作取出的元素外必須加乙個表——「 ()「

以下有幾個例子僅供參考!!!

e.g.

已知廣義表ls=((a,b,c),(d,e,f)),如果需要取出這個e這個元素,那麼使用tail和head如何將這個取出來。

tail取出來的始終是乙個表,即使只有乙個簡單的乙個元素,tail取出來的也是乙個表,而head取出來的可以是乙個元素也可以是乙個表。

解:

tail(ls) = ((d,e,f))

head(tail(ls)) = (d,e,f)

tail(head(tail(ls))) = (e,f) //無論如何都會加上這個()括號

head(tail(head(tail(ls)))) = e //head可以去除單個元素

(1)head ((p,h,w));

(2)tail((b,k,p,h));

(3) head (((a,b),(c,d)));

(4)tail(((a,b),(c,d)));

(5)head(tail(((a,b),(c,d))));

(6)tail(head((((a,b),(c,d)))).

答:  

(1)head ((p,h,w))=p; 

(2)tail((b,k,p,h))=(k,p,h); 

(3)head (((a,b),(c,d)))=(a,b);

(4)tail(((a,b),(c,d)))=((c,d));-----------------注意三和四返回結果的 區別 (取表尾運算子得到的結果一定為乙個子表)

(5)head(tail(((a,b),(c,d))))=(c,d);

(6)tail(head(((a,b),(c,d))))=(b).

tail(a)=(b,(c,d),(e,(f,g)));

tail(tail(a))=((c,d),(e,(f,g)));

head(tail(tail(a)))=(c,d);

tail(head(tail(tail(a))))=(d);

head(tail(head(tail(tail(a)))))=d;

廣義表的head 和tail運算

1 利用廣義表的head和tail操作寫出函式表示式,把以下各題中的單元素banana從廣義表中分離出來 答案 1 head tail tail l1 2 head head tail l2 3 head head tail tail head l3 4 head head tail tail l4...

linux的head和tail命令

1 head 工具,顯示檔案內容的前幾行 head 是顯示乙個檔案的內容的前多少行 用法比較簡單 de head n 行數值 檔名 de 比如我們顯示 etc profile的前10行內容,應該是 de root localhost head n 10 etc profile de 2 tail 工...

linux中tail和head指令

1.如果你只想看檔案的前5行,可以使用head命令,如 head 5 etc passwd 2.如果你想檢視檔案的後10行,可以使用tail命令,如 tail 10 etc passwd 或 tail n10 etc passwd tail f var log messages 引數 f使tail不...