計(jì)算機(jī)科學(xué)和Python編程導(dǎo)論 week7&期末考試

一基礎(chǔ)學(xué)習(xí)

1.pylab 模塊是一款由python提供的可以繪制二維,三維數(shù)據(jù)的工具模塊泡躯,其中包括了繪圖軟件包 matplotlib,其可以生成matab繪圖庫的圖像。?

安裝pylab模塊:pylab是matplotlib中的一個(gè)模塊 所以我們直接安裝matplotlib庫。

pip install matplotlib

例子:y = 2x

import pylab

my_list=[ ]

for counter in range(10):

? ? my_list.append(counter*2)

print my_list

print len(my_list)

#now plot the list

pylab.plot(my_list)

pylab.show()

圖 y = 2x


2.數(shù)據(jù)結(jié)構(gòu)-樹

樹是一種非線性的數(shù)據(jù)結(jié)構(gòu)精续,是由n(n >=0)個(gè)結(jié)點(diǎn)組成的有限集合。

如果n==0粹懒,樹為空樹重付。

如果n>0,

樹有一個(gè)特定的結(jié)點(diǎn)凫乖,根結(jié)點(diǎn)

根結(jié)點(diǎn)只有直接后繼确垫,沒有直接前驅(qū)。

除根結(jié)點(diǎn)以外的其他結(jié)點(diǎn)劃分為m(m>=0)個(gè)互不相交的有限集合帽芽,T0删掀,T1,T2导街,...披泪,Tm-1,每個(gè)結(jié)合是一棵樹搬瑰,稱為根結(jié)點(diǎn)的子樹款票。

數(shù)據(jù)結(jié)構(gòu)中有很多樹的結(jié)構(gòu),其中包括二叉樹泽论、二叉搜索樹艾少、2-3樹、紅黑樹等等翼悴。


圖 樹的示意圖

樹的度/樹的前驅(qū)后繼/樹的層次/樹的有序性/森林等概念參考博文學(xué)習(xí):http://blog.51cto.com/9291927/2068745

3.樹的遍歷

不要帶著二叉樹的遍歷來限制了對樹的遍歷的理解缚够。?

樹的遍歷的定義:以某種方式訪問樹中的每一個(gè)結(jié)點(diǎn),且僅訪問一次鹦赎。?

樹的遍歷主要有先根遍歷后根遍歷谍椅。

先根遍歷:若樹非空,則先訪問根結(jié)點(diǎn)古话,再按照從左到右的順序遍歷根結(jié)點(diǎn)的每一棵子樹毯辅。這個(gè)訪問順序與這棵樹對應(yīng)的二叉樹的先序遍歷順序相同

后根遍歷:若樹非空煞额,則按照從左到右的順序遍歷根結(jié)點(diǎn)的每一棵子樹思恐,之后再訪問根結(jié)點(diǎn)。其訪問順序與這棵樹對應(yīng)的二叉樹的中序遍歷順序相同膊毁。

森林的遍歷:需要注意的是胀莹,只有二叉樹森林才有中序遍歷與完整二叉樹中序遍歷對應(yīng)?

先序遍歷森林。

博文學(xué)習(xí):樹的常見算法&圖的DFS和BFS(https://www.cnblogs.com/LUO77/p/5839273.html)


二練習(xí)錯(cuò)題

1.證明算法的正確性

要做下面的事情:

● 合法輸入數(shù)據(jù)的說明

● 輸入和期望輸出之間的關(guān)系

算法的正確性:整體正確和部分正確

證明正確性的時(shí)候我們一般分兩個(gè)階段:

● 一用不變式來證明算法的部分正確性婚温。不變式指的是依附于算法中的一條特定的語句描焰,該語句對計(jì)算的結(jié)果狀態(tài)進(jìn)行判斷。

● 二用收斂性來嚴(yán)整算法的整體正確性。收斂性是證明算法在特定的合法輸入數(shù)據(jù)的情況下荆秦,會正常結(jié)束的一種方法篱竭。

2.樹的練習(xí)


題6

def set_children(self, mother, list_of_children):

? ? ? ? # convert name to Member node (should check for validity)

? ? ? ? mom_node = self.names_to_nodes[mother]?

? ? ? ? # add each child

? ? ? ? for c in list_of_children:? ? ? ? ?

? ? ? ? ? ? # create Member node for a child?

? ? ? ? ? ? c_member = Member(c)? ? ? ? ? ? ?

? ? ? ? ? ? # remember its name to node mapping

? ? ? ? ? ? self.names_to_nodes[c] = c_member? ?

? ? ? ? ? ? # set child's parent

? ? ? ? ? ? c_member.add_parent(mom_node)? ? ? ?

? ? ? ? ? ? # set the parent's child

? ? ? ? ? ? mom_node.add_child(c_member)? ? ? ?


? ? def is_parent(self, mother, kid):

? ? ? ? mom_node = self.names_to_nodes[mother]

? ? ? ? child_node = self.names_to_nodes[kid]

? ? ? ? return child_node.is_parent(mom_node)?

? ? def is_child(self, kid, mother):

? ? ? ? mom_node = self.names_to_nodes[mother]?

? ? ? ? child_node = self.names_to_nodes[kid]

? ? ? ? return mom_node.is_child(child_node)


3.PROBLEM 7

題7

#7-1

definsert(atMe, newFrob):

? ??if newFrob.name == atMe.name:?

?????????newFrob.after = atMe.after?

?????????atMe.after = newFrob?

?????????newFrob.before = atMe

????????if newFrob.after:

?????????????newFrob.after.before = newFrob

? ??elif newFrob.name < atMe.name:

????????if not atMe.before:

????????????atMe.before = newFrob?

? ? ? ? ? ? newFrob.after = atMe

? ??????elif atMe.before and atMe.before == newFrob.before:?

? ? ? ? ? ? newFrob.after = atMe?

? ? ? ? ? ? atMe.before = newFrob?

? ? ? ? ? ? newFrob.before.after = newFrob

????????else:

? ??????????newFrob.after = atMe

? ? ? ? ? ? insert(atMe.before, newFrob)

? ??else:

????????if atMe.after and atMe.after == newFrob.after:?

?????????????newFrob.before = atMe?

?????????????atMe.after = newFrob?

?????????????newFrob.after.before = newFrob

????????elif atMe.after ==None:?

?????????????atMe.after = newFrob?

?????????????newFrob.before = atMe

????????else:?

?????????????newFrob.before = atMe?

?????????????insert(atMe.after, newFrob)

#7-2

def findFront(start):

? ??if not start.getBefore():

????????return start

????else:

return findFront(start.getBefore())

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市步绸,隨后出現(xiàn)的幾起案子掺逼,更是在濱河造成了極大的恐慌,老刑警劉巖瓤介,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吕喘,死亡現(xiàn)場離奇詭異,居然都是意外死亡刑桑,警方通過查閱死者的電腦和手機(jī)氯质,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來祠斧,“玉大人闻察,你說我怎么就攤上這事∽练妫” “怎么了蜓陌?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長吩蔑。 經(jīng)常有香客問我钮热,道長,這世上最難降的妖魔是什么烛芬? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任隧期,我火速辦了婚禮,結(jié)果婚禮上赘娄,老公的妹妹穿的比我還像新娘仆潮。我一直安慰自己,他們只是感情好遣臼,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布性置。 她就那樣靜靜地躺著,像睡著了一般揍堰。 火紅的嫁衣襯著肌膚如雪鹏浅。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天屏歹,我揣著相機(jī)與錄音隐砸,去河邊找鬼。 笑死蝙眶,一個(gè)胖子當(dāng)著我的面吹牛季希,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼式塌,長吁一口氣:“原來是場噩夢啊……” “哼博敬!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起峰尝,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤偏窝,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后境析,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體囚枪,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡派诬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年劳淆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片默赂。...
    茶點(diǎn)故事閱讀 40,001評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡沛鸵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出缆八,到底是詐尸還是另有隱情曲掰,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布奈辰,位于F島的核電站栏妖,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏奖恰。R本人自食惡果不足惜吊趾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望瑟啃。 院中可真熱鬧论泛,春花似錦、人聲如沸蛹屿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽错负。三九已至坟瓢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間犹撒,已是汗流浹背载绿。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留油航,地道東北人崭庸。 一個(gè)月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親怕享。 傳聞我的和親對象是個(gè)殘疾皇子执赡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 我不詳細(xì)地知道自己是在何種情況下出生的沙合,應(yīng)該是千千萬萬情況中平凡的一種。像萬眾矚目跌帐,遭受白眼或是忿恨的情況是沒有的...
    盛夏之頌閱讀 261評論 0 2
  • 也許我天生便是胸?zé)o大志的吧首懈,對于生活的態(tài)度,常與別人不同谨敛,更趨向于寂靜究履。 今天下午遇到一位良善的老板,可是闊氣脸狸。一...
    化濁閱讀 352評論 3 7
  • 有人說最仑,溫和是教養(yǎng)。 簡一發(fā)信息給蘇:我現(xiàn)在才知道你把我寵壞了炊甲,沒人受得了壞脾氣泥彤,我不知道要怎么辦,只有你才能讓我...
    vitasu閱讀 426評論 0 2
  • 老槐樹下經(jīng)過 記憶中一個(gè)傳頌千載的故事 讓我倍感幸福 雖然在這以前 都走得人困馬乏 月光鋪開 李白和他愉悅的影子 ...
    龍生于海閱讀 258評論 10 27