亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤.htm

?? 象棋程序設(shè)計(jì)全資料集(介紹編寫象棋程序的方法思路)
?? HTM
?? 第 1 頁 / 共 4 頁
字號:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0056)http://www.elephantbase.net/computer/struct_rotation.htm -->
<HTML><HEAD><TITLE>數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤</TITLE>
<META http-equiv=Content-Type content="text/html; charset=gb_2312-80">
<META content="MSHTML 6.00.3790.536" name=GENERATOR></HEAD>
<BODY background=數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/background.gif>
<DL>
  <DIV align=center>
  <CENTER>
  <DT><FONT size=3>《對弈程序基本技術(shù)》專題</FONT> </CENTER></DT></DIV>
  <DT>  
  <DIV align=center>
  <CENTER></DIV>
  <DT><FONT face=隸書 size=6>旋轉(zhuǎn)的位棋盤</FONT> </CENTER>
  <DIV></DIV>
  <DIV align=center>
  <CENTER></DIV>
  <DT>  </CENTER>
  <DIV></DIV>
  <DIV align=center>
  <CENTER></DIV>
  <DT>作者:<FONT face="Times New Roman">James Swafford (</FONT><A 
  href="mailto:james_swafford@hotmail.com"><FONT 
  face="Times New Roman">james_swafford@hotmail.com</FONT></A><FONT 
  face="Times New Roman">)</FONT> </CENTER>
  <DIV></DIV>
  <DT>  
  <DT><FONT color=#ff0000>  【編者的點(diǎn)評:這篇文章誤導(dǎo)了我近半年,而事實(shí)證明 </FONT><FONT 
  face="Times New Roman" color=#ff0000>James Swafford</FONT><FONT color=#ff0000> 
  的 </FONT><FONT face="Times New Roman" color=#ff0000>Galahad</FONT><FONT 
  color=#ff0000> 并不算是成功的引擎,現(xiàn)在互聯(lián)網(wǎng)上已經(jīng)找不到它的資料了。我在這里提醒讀者用懷疑的眼光來看本文</FONT><FONT 
  face="Times New Roman" color=#ff0000>(</FONT><FONT 
  color=#ff0000>包括我的注解</FONT><FONT face="Times New Roman" 
  color=#ff0000>)</FONT><FONT color=#ff0000>。】</FONT> 
  <DT>  “位棋盤”可以記錄的最有用的棋盤狀況之一就是“棋盤上哪些格子受到某一特定棋子的攻擊”。幸運(yùn)的是,這樣的計(jì)算耗時不多。對于那些活動能力不強(qiáng)的棋子,這可以說非常容易<FONT 
  face="Times New Roman">(</FONT>請看上節(jié)“位棋盤”<FONT face="Times New Roman">) 
  </FONT>。原因是:當(dāng)馬,國王或兵在特定格子上時,無論周圍情況怎樣變化,所攻擊的格子數(shù)目不變。你不用管那些格子上是否有棋子或者周圍是否有特殊情況。 
  </DT></DL>
<TABLE width="100%" border=0>
  <TBODY>
  <TR>
    <TD align=middle>馬在<FONT face="Times New Roman">D5</FONT>格可以攻擊到的格子</TD>
    <TD align=middle>國王在<FONT face="Times New Roman">D5</FONT>格可以攻擊到的格子</TD>
    <TD align=middle>黑棋的兵在<FONT 
face="Times New Roman">D5</FONT>格可以攻擊到的格子</TD></TR>
  <TR>
    <TD align=middle><IMG height=192 
      src="數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/struct_rotation1.gif" width=192></TD>
    <TD align=middle><IMG height=192 
      src="數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/struct_rotation2.gif" width=192></TD>
    <TD align=middle><IMG height=192 
      src="數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/struct_rotation3.gif" 
width=192></TD></TR></TBODY></TABLE>
<DL>
  <DT>  但是對于車,象和皇后,事情就不那么簡單了。例如,車攻擊橫線方向和豎線方向上的格子,直到在這兩個方向遇到第一個有棋子的格子為止<FONT 
  face="Times New Roman">(</FONT>包括這個有棋子的格子<FONT 
  face="Times New Roman">)</FONT>;如果沒有遇到有棋子的格子,則到棋盤邊界為止。也就是說,車所在橫線和豎線上的棋子分布情況不同,受到這個車攻擊的格子的數(shù)量也不一樣。因?yàn)槊織l橫線或豎線都有<FONT 
  face="Times New Roman">8</FONT>個格子,每個格子又有<FONT 
  face="Times New Roman">2</FONT>種狀態(tài)(有棋子或者沒有棋子),所以每條橫線或豎線都會有<FONT 
  face="Times New Roman">2<SUP>8</SUP>(256)</FONT>種棋子分布狀態(tài)。 
  <DT>  
  <DT><FONT face=楷體_GB2312 size=4><STRONG>用旋轉(zhuǎn)的位棋盤計(jì)算受車攻擊的格子</STRONG></FONT> 
  <DT>  
  <DT>  如何獲得整個棋盤上受到某個車攻擊的格子呢?最簡單的方法是:先計(jì)算出一個位棋盤記錄車所在橫線上受其攻擊的格子,在計(jì)算出另一個位棋盤記錄車所在豎線上受其攻擊的格子,最后用“邏輯或”把這兩個位棋盤“結(jié)合”到一起。 
  </DT></DL>
<TABLE width="100%" border=0>
  <TBODY>
  <TR>
    <TD align=middle>
      <TABLE border=0>
        <TBODY>
        <TR>
          <TD align=middle><IMG height=192 
            src="數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/struct_rotation4.gif" width=192></TD>
          <TD align=middle><FONT 
            face="Times New Roman"><STRONG>OR</STRONG></FONT></TD>
          <TD align=middle><IMG height=192 
            src="數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/struct_rotation5.gif" width=192></TD>
          <TD align=middle><FONT 
            face="Times New Roman"><STRONG>=</STRONG></FONT></TD>
          <TD align=middle><IMG height=192 
            src="數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/struct_rotation6.gif" 
        width=192></TD></TR></TBODY></TABLE></TD></TR></TBODY></TABLE>
<DL>
  <DT>  整個操作的關(guān)鍵在于“預(yù)先計(jì)算”。對于<FONT 
  face="Times New Roman">64</FONT>格中的每一格,都預(yù)先計(jì)算出當(dāng)車在這一格時,不同情況下橫線上受到攻擊的格子<FONT 
  face="Times New Roman">(</FONT>共<FONT 
  face="Times New Roman">256</FONT>種情況<FONT 
  face="Times New Roman">)</FONT>和不同情況下豎線上受到攻擊的格子<FONT 
  face="Times New Roman">(</FONT>也是<FONT face="Times New Roman">256</FONT>種<FONT 
  face="Times New Roman">)</FONT>。當(dāng)要尋找某一情況下受車攻擊的格子時,用橫線<FONT 
  face="Times New Roman">(</FONT>或豎線<FONT 
  face="Times New Roman">)</FONT>上的“棋子分布狀態(tài)”作索引從預(yù)先計(jì)算出來的位棋盤數(shù)組中取得。 
  <DT>  所以,第一步:預(yù)先計(jì)算出數(shù)組<FONT 
  face="Times New Roman">rank_attacks[64][256]</FONT>和<FONT 
  face="Times New Roman">file_attacks[64][256]</FONT>。 
  <DD>  
  <DD>/* 車或后橫向移動的預(yù)先計(jì)算 */ 
  <DD>for (棋盤上的每一格)(0-63) { 
  <DD> for (每行的棋子分布狀態(tài))(0-255) { 
  <DD>  計(jì)算該狀態(tài)下被占的格子 
  <DD>  計(jì)算從這個格子朝左走的著法 
  <DD>  計(jì)算從這個格子朝右走的著法 
  <DD>  rank_attacks[格子][橫線狀態(tài)] = attack_board; 
  <DD> } 
  <DD>} 
  <DD>/* 車或后縱向移動的預(yù)先計(jì)算 */ 
  <DD>for (棋盤上的每一格)(0-63) { 
  <DD> for (每條縱線的棋子分布狀態(tài))(0-255) { 
  <DD>  計(jì)算該狀態(tài)下被占的格子 
  <DD>  計(jì)算從這個格子朝上走的著法 
  <DD>  計(jì)算從這個格子朝下走的著法 
  <DD>  file_attacks[格子][縱線狀態(tài)] = attack_board; 
  <DD> } 
  <DD>} 
  <DT>  
  <DT>  第二步:索引<FONT 
  face="Times New Roman">rank_attacks[64][256]</FONT>,數(shù)組的第一個索引號為車所在格的編號。第二個索引號為車所在行上的“棋子分布狀態(tài)”。 

  <DT>  請看下面這個例子: </DT></DL>
<TABLE width="100%" border=0>
  <TBODY>
  <TR>
    <TD align=middle>車在<FONT face="Times New Roman">E6</FONT>格可以攻擊到的格子</TD></TR>
  <TR>
    <TD align=middle><IMG height=256 
      src="數(shù)據(jù)結(jié)構(gòu)——旋轉(zhuǎn)的位棋盤_files/struct_rotation7.gif" 
width=256></TD></TR></TBODY></TABLE>
<DL>
  <DT>  第一個索引號是<FONT face="Times New Roman">E6</FONT>格的編號。在我的程序里,它的編號是<FONT 
  face="Times New Roman">20</FONT>。第二個索引號是棋盤上第六行的棋子分布狀態(tài)。 
  <DD><FONT face="Times New Roman">0 1 0 1 0 0 1 0</FONT> 
  <DT>  <FONT color=#0000ff>【編者注:在</FONT><FONT face="Times New Roman" 
  color=#0000ff>James Swafford</FONT><FONT color=#0000ff>的程序里,由于</FONT><FONT 
  face="Times New Roman" color=#0000ff>A8</FONT><FONT 
  color=#0000ff>格編號為</FONT><FONT face="Times New Roman" 
  color=#0000ff>0</FONT><FONT 
  color=#0000ff>,所以這串?dāng)?shù)據(jù)的順序正好和棋盤相反,跟黑方看上去的順序相同。】</FONT> 
  <DT>  要分離出上面這個數(shù)字,我們需要對位棋盤執(zhí)行一個“位移<FONT 
  face="Times New Roman">(shift)</FONT>”和一個“邏輯與”指令。在我的程序中,<FONT 
  face="Times New Roman">A8</FONT>格的編號為<FONT 
  face="Times New Roman">0</FONT>。如果車在第<FONT 
  face="Times New Roman">8</FONT>行的任意格子上則不需要執(zhí)行位移;若在第<FONT 
  face="Times New Roman">7</FONT>行則要右移<FONT 
  face="Times New Roman">8</FONT>位;在第<FONT 
  face="Times New Roman">6</FONT>行要右移<FONT 
  face="Times New Roman">16</FONT>位;以此類推。 </DT></DL>
<TABLE width="100%" border=0>
  <TBODY>
  <TR>
    <TD align=middle>需要右移的位數(shù)</TD></TR>
  <TR>
    <TD align=middle>
      <TABLE border=1>
        <TBODY>
        <TR>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>0</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>0</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>0</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>0</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>0</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>0</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>0</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>0</STRONG></FONT></TD></TR>
        <TR>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>8</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>8</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>8</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>8</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>8</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>8</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>8</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>8</STRONG></FONT></TD></TR>
        <TR>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>16</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>16</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>16</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>16</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>16</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>16</STRONG></FONT></TD>
          <TD align=middle bgColor=#ffffff><FONT 
            face="Times New Roman"><STRONG>16</STRONG></FONT></TD>
          <TD align=middle bgColor=#000000><FONT face="Times New Roman" 
            color=#ffffff><STRONG>16</STRONG></FONT></TD></TR>
        <TR>

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久三区| 日韩**一区毛片| 欧美一区二区国产| 成人黄色电影在线 | 成人动漫在线一区| 日韩av不卡一区二区| 亚洲日穴在线视频| 国产日韩v精品一区二区| 欧美人动与zoxxxx乱| 99免费精品在线| 精品在线观看视频| 日韩制服丝袜av| 亚洲精品中文在线| 中文字幕一区二区三区不卡| 26uuu精品一区二区| 日韩无一区二区| 欧美精品国产精品| 欧美性大战久久久久久久| 99久久99久久精品免费看蜜桃| 韩国成人福利片在线播放| 日日欢夜夜爽一区| 亚洲3atv精品一区二区三区| 亚洲人午夜精品天堂一二香蕉| 亚洲国产高清在线观看视频| 久久综合色综合88| 欧美大片一区二区三区| 欧美精品欧美精品系列| 欧美日韩精品欧美日韩精品一| 日本高清免费不卡视频| av综合在线播放| 99热精品一区二区| 本田岬高潮一区二区三区| 成人av在线资源网站| 国产精品一区二区三区四区| 国产精品自产自拍| 国产成人av资源| 国产精品亚洲一区二区三区妖精| 国产麻豆午夜三级精品| 国产一区二区按摩在线观看| 精品系列免费在线观看| 紧缚捆绑精品一区二区| 国产精品资源网| 国产成人日日夜夜| k8久久久一区二区三区 | 亚洲国产精品一区二区尤物区| 亚洲一区二区三区爽爽爽爽爽 | 天堂一区二区在线免费观看| 午夜视黄欧洲亚洲| 美女性感视频久久| 国产乱子伦视频一区二区三区| 韩国成人在线视频| 成人av免费观看| 色综合中文综合网| 亚洲精品菠萝久久久久久久| 亚洲成人三级小说| 日韩一区欧美二区| 精品一区二区三区影院在线午夜 | 亚洲综合视频网| 午夜影院在线观看欧美| 日韩av中文在线观看| 捆绑调教美女网站视频一区| 国产一区二区三区视频在线播放| 国产成人av影院| 色视频欧美一区二区三区| 欧美美女网站色| 欧美变态tickling挠脚心| 26uuu精品一区二区在线观看| 国产精品久久毛片av大全日韩| 亚洲黄色录像片| 日本成人在线不卡视频| 国产真实乱对白精彩久久| 丁香网亚洲国际| 欧美四级电影网| 亚洲精品一区二区在线观看| 国产精品欧美极品| 午夜私人影院久久久久| 国产精品亚洲一区二区三区在线 | 精品国产一区二区国模嫣然| 亚洲欧美在线aaa| 日韩—二三区免费观看av| 国产一区二区三区免费| 91麻豆免费看片| 日韩精品一区二区三区视频| ●精品国产综合乱码久久久久| 亚洲超碰精品一区二区| 国产91色综合久久免费分享| 色又黄又爽网站www久久| 欧美大白屁股肥臀xxxxxx| 亚洲欧洲精品一区二区三区| 奇米色777欧美一区二区| www.日韩精品| 欧美成va人片在线观看| 亚洲精品国产成人久久av盗摄| 久久99精品久久久久久久久久久久| 91在线看国产| 2021中文字幕一区亚洲| 亚洲va韩国va欧美va| 成人av在线电影| 日韩欧美国产三级| 一片黄亚洲嫩模| 成人黄色在线看| 久久亚洲捆绑美女| 日日夜夜免费精品| 色噜噜狠狠色综合中国| 国产蜜臀av在线一区二区三区 | 91在线丨porny丨国产| 久久亚洲春色中文字幕久久久| 亚洲国产你懂的| 色综合久久中文综合久久97| 国产日本欧洲亚洲| 毛片一区二区三区| 欧美日韩一二三| 日韩美女视频一区二区 | 91精品国产一区二区三区香蕉| 国产精品传媒在线| 成人在线视频一区二区| 精品成人a区在线观看| 日本视频一区二区三区| 在线观看亚洲专区| 亚洲欧美色综合| 99精品视频中文字幕| 国产清纯美女被跳蛋高潮一区二区久久w| 日韩精品乱码免费| 777精品伊人久久久久大香线蕉| 亚洲欧美激情一区二区| 91亚洲资源网| 国产精品国产自产拍在线| 国产91露脸合集magnet| 久久在线免费观看| 国产一区二区免费看| 久久中文字幕电影| 国产成人精品免费在线| 欧美激情综合在线| 丰满白嫩尤物一区二区| 国产日产欧美一区| 成人国产亚洲欧美成人综合网| 久久久久国产精品麻豆 | 欧美一三区三区四区免费在线看 | 91蝌蚪porny| 一区二区三区中文在线观看| 色婷婷综合久久久中文一区二区| 亚洲日本丝袜连裤袜办公室| 91亚洲大成网污www| 亚洲色欲色欲www在线观看| 91在线观看美女| 亚洲精品乱码久久久久久久久| 色偷偷88欧美精品久久久| 亚洲成人手机在线| 日韩丝袜美女视频| 国产精品一区二区三区四区| 中文字幕日韩av资源站| 欧美最新大片在线看| 婷婷久久综合九色国产成人| 欧美xxxxx牲另类人与| 国产福利91精品| 亚洲欧洲美洲综合色网| 欧美日韩国产成人在线免费| 日本成人在线视频网站| 国产肉丝袜一区二区| 色综合久久88色综合天天6| 视频在线观看国产精品| 久久综合久久综合亚洲| 不卡的av中国片| 亚洲18色成人| 久久天天做天天爱综合色| 99精品视频一区| 日本欧洲一区二区| 国产欧美精品一区| 欧美亚洲综合另类| 韩日精品视频一区| 亚洲色欲色欲www| 日韩一级片网站| 成人一区在线看| 亚洲国产成人porn| 国产欧美精品一区二区三区四区 | 国产精品一级黄| 亚洲天堂精品视频| 3d成人动漫网站| 国产69精品久久99不卡| 亚洲国产乱码最新视频 | 日韩欧美一二三四区| 久久综合av免费| 日本国产一区二区| 日韩va亚洲va欧美va久久| 久久久久88色偷偷免费| 欧美一区二区三区视频| 欧美四级电影网| 日本二三区不卡| 99精品久久只有精品| 国产成人啪免费观看软件| 久久精品国产久精国产爱| 日韩精品五月天| 亚洲成av人片在线观看| 亚洲午夜精品久久久久久久久| 综合久久久久久| 中文天堂在线一区| 国产精品污网站| 国产精品国产自产拍在线| 中文字幕+乱码+中文字幕一区| 久久免费视频色|