-
Data: 2012-04-17 18:32:51
Temat: Re: zaawansowane ai
Od: " " <f...@N...gazeta.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]M.M. <m...@N...gazeta.pl> napisał(a):
> <f...@N...gazeta.pl> napisał(a):
>
> > o jakim grafie ty mowisz? ja nie mam zadnych grafow tylko mape
> > ktorej okolice czytam, nie bardzo wiem do czego uzywa sie grafow
> > w programoaniu np programow do gry w warcaby czy tic tac toe
> > - nie zajmowalem sie tym,
> To przypomnij sobie czasy gdy pisałeś A* :D
>
mam tu kod algorytmu na najkrotsza droge sprzed 10 lat (z poczatkow
nauki c) (nie chce mi sie tego czytac ale gdybym mial teraz to zrobic to
bym tylko troche poprawil owczesny 'drewniany styl' (glupie nazwy itd)
i tego mw i dzis uzyl (jest w c wiec jest dosyc szybkie)
polega to na wypoczkowaniu kolejnej obwodki z poprzedniej az dojedzie sie
do celu - nie pamietam jak to jest dokladnie z tym grafem i jak to jest
'wszerz'
void wypelnijmapeskalaremodleglosci(int XS, int YS, int XK, int YK)
{
int dx[8]={-1,0,1,-1,1,-1, 0, 1};
int dy[8]={ 1,1,1, 0,0,-1,-1,-1};
#define MAX_POJ_NACZOLOFALI 3000
TypeTWOINT lista1[MAX_POJ_NACZOLOFALI];
TypeTWOINT lista2[MAX_POJ_NACZOLOFALI];
TypeTWOINT* listaprzerabianych=lista1;
TypeTWOINT* listapaczkowanych=lista2;
TypeTWOINT* tmp;
int value_paczkowanych=1; // p/on/czkowanych tj. tworzonych w nowej
generacji z listy przerabianych
int j=0; // tutaj i jest aktualna pozycja na liscie
przerabianych, j na tworzonych
int czykonczymy=FALSE;
//ini - od takiej krotkiej listy startujemy
listaprzerabianych[0].x=XK;
listaprzerabianych[0].y=YK; VGAEKRAN[320*YK+XK]=0;
listaprzerabianych[1].x=KONIEC_OZN;
do
{
for(int i=0; i<MAX_POJ_NACZOLOFALI;i++)
{
if(listaprzerabianych[i].x==KONIEC_OZN) break;
// paczkuj_nowe_dookola_punktu
for(int ii=0; ii<8; ii++)
{
int xp=listaprzerabianych[i].x+dx[ii];
int yp=listaprzerabianych[i].y+dy[ii];
if(value_paczkowanych<VGAEKRAN[320*yp+xp] && VGAEKRAN[320*yp+xp]!
=255)
{
listapaczkowanych[j].x=xp;
listapaczkowanych[j].y=yp;
VGAEKRAN[320*yp+xp]=value_paczkowanych;
j++;
if(xp==XS && yp==YS) czykonczymy=TRUE;
}
}
}
listapaczkowanych[j].x=KONIEC_OZN;
//odwrocenie macierzy i od nowa
tmp=listapaczkowanych; listapaczkowanych=listaprzerabianych;
listaprzerabianych=tmp;
j=0; value_paczkowanych++;
}
while(!czykonczymy);
}
void narysujterazdroge(int XS, int YS)
{
int dx[8]={-1,0,1,-1,1,-1, 0, 1};
int dy[8]={ 1,1,1, 0,0,-1,-1,-1};
int x=XS;
int y=YS;
int xp, yp;
do {
//------
for(int i=0; i<8; i++)
{
xp=(x+dx[i]);
yp=(y+dy[i]);
unsigned valx=VGAEKRAN[320*y+x];
unsigned valxp=VGAEKRAN[320*yp+xp];
if(valxp==0) return;
if(valxp<valx) break;
}
//-------- w xp yp jest teraz nizszy sasiad x y
VGAEKRAN[320*y+x]=150;
x=xp; y=yp;
// delay(10);
} while(1);
}
>
> > za to kiedys klepalem dosyc duzo roguelika
> > (ktory jest wlasnie tilowym erpegiem z botami) i mam w tym troche
> > doswiadczenia (swietnie sie programuje takie rzeczy ijest tu
> > duzo ciekawych tematow - kiedys indziej napisze o tym wiecej)
> Ja za to nie wiem co to jest tilowy erpeg :)
>
> Pozdrawiam
>
>
--
Wysłano z serwisu Usenet w portalu Gazeta.pl -> http://www.gazeta.pl/usenet/
Następne wpisy z tego wątku
- 17.04.12 18:42 M.M.
- 17.04.12 19:16
- 17.04.12 19:29
- 17.04.12 20:01 M.M.
- 17.04.12 20:29 Jordan Szubert
- 17.04.12 21:20 M.M.
- 19.04.12 17:03
- 19.04.12 17:49 zażółcony
- 20.04.12 10:26 zażółcony
- 20.04.12 10:50 Jordan Szubert
- 20.04.12 13:45 A.L.
- 20.04.12 20:00 M.M.
- 21.04.12 00:14 M.M.
- 04.05.12 15:59 zażółcony
- 04.05.12 16:26
Najnowsze wątki z tej grupy
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
Najnowsze wątki
- 2025-05-15 Nowy rodzaj zagrożenie ze strony elektryków :)
- 2025-05-15 Bus inpostu, przemycający ludzi, walnął w nocy w tira zaparkowanego na autostradzie 5 ofiar
- 2025-05-15 Alert RCB w sprawie dziewczynki
- 2025-05-15 Kurierski bus przemycał ludzi i zasnął nad ranem za kierownicą.
- 2025-05-15 Dęblin => JavaScript / Node / Fullstack Developer <=
- 2025-05-14 Tsue i smsy
- 2025-05-14 Biedna kobieta jechała samochodem na targ aby sprzedać klamoty i dostała 300 zł mandatu
- 2025-05-14 hot spot traci connected device
- 2025-05-14 John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- 2025-05-14 John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- 2025-05-14 Wariant rumuński
- 2025-05-14 Rolnicy protestują w Szczecinie
- 2025-05-14 Rolnicy protestują w Szczecinie
- 2025-05-14 Rolnicy protestują w Szczecinie
- 2025-05-14 Niemcy: Przychody ze sprzedaży produktów Fairtrade w 2024r. wzrosły o rekordowe 13% do 2,9GEUR