史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 程式語言討論區
忘記密碼?
論壇說明

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2008-04-26, 10:20 PM   #1
elix
註冊會員
榮譽勳章

勳章總數
UID - 299315
在線等級: 級別:0 | 在線時長:4小時 | 升級還需:1小時
註冊日期: 2008-04-25
文章: 2
精華: 0
現金: 3 金幣
資產: 3 金幣
預設 疑問 - C語言問題請各位大大幫忙

請各位大大幫忙~如何印六角型的迷宮牆且判斷要找到最近的路,從S走到E. 現在還在打轉. 如圖

http://img176.imageshack.us/img176/7356/tmp968ng2.jpg

此帖於 2008-04-27 10:35 AM 被 不飛 編輯.
elix 目前離線  
送花文章: 2, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
舊 2008-04-27, 04:01 AM   #2 (permalink)
註冊會員
榮譽勳章
UID - 293162
在線等級: 級別:2 | 在線時長:18小時 | 升級還需:3小時級別:2 | 在線時長:18小時 | 升級還需:3小時
註冊日期: 2008-02-12
文章: 327
精華: 0
現金: 16 金幣
資產: 16941 金幣
預設

我只說明對應結構的部份,把六角形的地圖對印到二維矩陣
至於走法只有6個方向,看你結構對應的方式決定對應的方向
如果對應好了搜尋的算法也不用擔心,有太多算法
接下來麻煩的地方就是秀出圖形
rank 目前離線  
送花文章: 362, 收花文章: 221 篇, 收花: 411 次
回覆時引用此帖
向 rank 送花的會員:
elix (2008-04-27)
感謝您發表一篇好文章
舊 2008-04-27, 03:47 PM   #3 (permalink)
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時
註冊日期: 2002-12-07
文章: 13249
精華: 0
現金: 26241 金幣
資產: 3024051 金幣
預設

幫你兩個地方 (個人不會 c/c++ 之印圖的語法,但如何邏輯式印圖其實沒這麼複雜)
.先看圖
http://xs226.xs.to/xs226/08170/d6725.jpg

只要畫出 座標的記憶體配置方式
就可根據 可通行的方向
訂出六條通路之判斷語法


.六條通路之判斷語法 如下 (這裡個人用 VB寫)
語法:
'X 及 Y 是新的座標,iNO 是試問的方向(1~6),當(X,Y)可通時 IsDirectionOK=True
Public Function IsDirectionOK(iNO As Integer, X As Integer, Y As Integer) As Boolean
    '(NowX,NowY) 是目前老鼠的座標
    Select Case iNO
    Case 1
        X = NowX
        Y = NowY - 1
    Case 2
        X = NowX + 1
        Y = NowY - 1
    Case 3
        X = NowX + 1
        Y = NowY
    Case 4
        X = NowX
        Y = NowY + 1
    Case 5
        X = NowX - 1
        Y = NowY
    Case 6
        X = NowX - 1
        Y = NowY - 1
    Else Case 
        'IsDirectionOK = False
        Exit Function
    End Select
    
    'MapXMax 及 MapYMax 記憶體陣列的 X,Y size
    If (X < 0 Or Y < 0) And (X <= MapXMax Or Y <= MapYMax) Then
        'IsDirectionOK = False
    Else
        'Map為 地圖之記憶體陣列,內容為0 表示此方向無阻礙
             If Map(X, Y) = 0 Then IsDirectionOK = True
    End If

End Function

至於函式 IsDirectionOK 要傳那個方向
這就由您自己決定
最間單就是依序 1~6
另外也可用 範圍規範式的1~6亂數 選擇


如何使用
語法:
'D 是您決定測試的方向
If IsDirectionOK(D, X, Y) = True Then
    NowX = X
    NowY = Y
End If

此帖於 2008-04-27 04:31 PM 被 mini 編輯. 原因: 修辭
mini 目前離線  
送花文章: 1999, 收花文章: 7957 篇, 收花: 26749 次
回覆時引用此帖
有 2 位會員向 mini 送花:
elix (2008-04-27),rank (2008-04-28)
感謝您發表一篇好文章
舊 2008-04-27, 08:29 PM   #4 (permalink)
註冊會員
榮譽勳章

勳章總數
UID - 299315
在線等級: 級別:0 | 在線時長:4小時 | 升級還需:1小時
註冊日期: 2008-04-25
文章: 2
精華: 0
現金: 3 金幣
資產: 3 金幣
預設

wah~好複雜喔
還是謝謝!!
elix 目前離線  
送花文章: 2, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
舊 2008-04-28, 05:20 AM   #5 (permalink)
註冊會員
榮譽勳章
UID - 293162
在線等級: 級別:2 | 在線時長:18小時 | 升級還需:3小時級別:2 | 在線時長:18小時 | 升級還需:3小時
註冊日期: 2008-02-12
文章: 327
精華: 0
現金: 16 金幣
資產: 16941 金幣
預設

很感謝mini版主做那麼仔細的教學
不過在實作上仍有一些差異就是
rank 目前離線  
送花文章: 362, 收花文章: 221 篇, 收花: 411 次
回覆時引用此帖
發文 回覆



發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用

相似的主題
主題 主題作者 討論區 回覆 最後發表
求助 - 電腦偶爾都會出現一個小視窗?請各位大大幫幫忙? em17990 一般電腦疑難討論區 1 2006-11-30 10:52 AM
DVDX2.0轉檔問題各位大大幫幫忙 ECKO 軟體應用問題討論區 1 2003-04-30 01:45 AM
騾子?驢子?網址?請各位大大幫忙! i78524 軟體應用問題討論區 6 2003-04-27 03:46 PM
注意字型(請各位大大幫幫忙~~~) sonyo 一般電腦疑難討論區 5 2003-04-01 09:44 PM


所有時間均為台北時間。現在的時間是 04:56 PM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2024, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1