友情提示:如果本网页打开太慢或显示不完整,请尝试鼠标右键“刷新”本网页!阅读过程发现任何错误请告诉我们,谢谢!! 报告错误
狗狗书籍 返回本书目录 我的书架 我的书签 TXT全本下载 进入书吧 加入书签

VB2008从入门到精通(PDF格式英文版)-第41章

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!





…………………………………………………………Page 100……………………………………………………………

78         CH AP T E R   4   ■    L E A R N IN G   AB OU T   D AT A  S TR U CT U R E S;   DE CI SI ON S;   A N D   L O OP S 



           ■Note  An algorithm is a logical set of finite; repeatable steps for pleting a task。 The term is usually  

           applied in relation to formal problems such as searching; but most; if not all puter programs; use algo

           rithms of one sort or another。 



                 Before we write any code; you need to understand what the depth…first search algorithm  

           does and why you would use it。 The problem to solve is how to get from point A to point B in  

           the most efficient manner。 This problem can be stated generally as; “how to solve task A when  

           you have X options。” 

                 Imagine you are about to drive to work and you are at the front door of your house。 You  

           don’t know where your keys are; and thus you begin a search for the keys in the house。 Of  

           course; you try to remember; but your memory is not working that early in the morning。 You  

           try to retrace your steps; and think of logical places where you could have placed your keys。  

           When you retrace your steps; you follow your memory’s logic。 Simply put; your search algo

           rithm is based on your memory’s suggestion of where the keys might be。 The data structure  

           that you are navigating is the rooms of your house。 Your brain…based search algorithm could  

           create a search pattern like that shown in Figure 4…1。 



           Figure 4…1。 A possible search order for your keys 



                 In Figure 4…1; you found the keys in the hall; but yet your search algorithm led you astray  

           for a while; since you searched the hall last。 The cynic could say that you kept walking around  

           the keys without realizing that they were so close to you。 But this is the crux of the problem;  

           because you didn’t know you developed a search algorithm that would lead you astray this  

           time。 And the same algorithm might not lead you astray next time。  


…………………………………………………………Page 101……………………………………………………………

                          CH AP T E R   4   ■    L E A R N I N G   A B OU T   D AT A  S TR U CT U R E S;   DE CI SI ON S;   A N D   L O OP S 79 



■Note  Searching using different strategies is very similar to how you will write puter algorithms。 There  

is no single best algorithm; there are only good algorithms that have certain promises。 When you imple

ment an algorithm; you need to consider the one that best suits your needs with the least number of  

promises that could cause problems。 



      As Figure 4…1 illustrates; you searched in a counterclockwise manner。 Another strategy  

would have been to go clockwise or even in a zigzag; or you could have searched some rooms  

multiple times。  

      Let’s convert Figure 4…1 into a program that has a search algorithm and a data structure。  

The search algorithm will be depth…first; and the data structure will be based on a path between  

the respective rooms。 The data structure representing the house in Figure 4…1 is illustrated in  

Figure 4…2。 



Figure 4…2。 A tree structure illustrates each possible action。 Highlighted lines represent a depth

first search; and each circle represents a destination。 


…………………………………………………………Page 102……………………………………………………………

80         CH AP T E R   4   ■    L E A R N IN G   AB OU T   D AT A  S TR U CT U R E S;   DE CI SI ON S;   A N D   L O OP S 



                 In the tree structure shown in Figure 4…2; each node represents a destination that can be  

           reached from a particular place in the house。 From each room; you can reach the other room。  

           But this structure is recursive。 From the child bedroom; you can reach the living room; and  

           then you can reach the child bedroom again。 Even though you navigated down the tree; you  

           moved from one room to another and back to the original room。 This is perfectly acceptable  

           from a data structure perspective; even though you are probably saying; “But that is wrong  

           since rooms will show up multiple times。” 



           ■Note  The tree representation in Figure 4…2 is by no means plete; because from each room you can  

           go to the other room。 A full tree representation would be a binatorial explosion。 



                The structure is the way it is because the data structure is a representation of the house。 If  

           you were searching the house; would you be able to move from one room to another and back  

           again? Sure you would。 Would you do it? No; because your search algorithm would say; “Hey  

           dude; you’re repeating yourself。” And therein lies the trick when writing applications。 You have  

           a data structure and an algorithm that operates on the data structure。 I call this building an  

           application in layers。 You have the lowest level; which is an intelligent data structure; and a  

           higher level that uses the functionality of the intelligent data structure。 

                 By  intelligent data structure; I mean that the structure is always consistent and does not  

           corrupt itself。 In this example; a room will not point to itself; a room will be present in the struc

           ture only if it is present in the house; and so on。 The higher…level algorithm would be responsible  

           for figuring out how to find information in the tree。 It should be smart enough to realize that  

           constantly traveling between two rooms is not going to achieve anything other than wasted  

           time。 

                The search logic is where you go down the tree traversing one room after another。 It is  

           called a depth…first search algorithm because you iterate the tree by going down the tree one  

          
返回目录 上一页 下一页 回到顶部 0 0
未阅读完?加入书签已便下次继续阅读!
温馨提示: 温看小说的同时发表评论,说出自己的看法和其它小伙伴们分享也不错哦!发表书评还可以获得积分和经验奖励,认真写原创书评 被采纳为精评可以获得大量金币、积分和经验奖励哦!