Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Realizzato da Lenovo e installato presso il Cineca di Casalecchio di Reno, Pitagora offre circa 44 PFlop/s di potenza di calcolo ed è dedicato alla simulazione della fisica del plasma e allo studio dei materiali avanzati per la fusione, integrandosi nell’ecosistema del Tecnopolo di Bologna come infrastruttura strategica finanziata da EUROfusion e gestita in collaborazione con ENEA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Rullo di lavaggio dei pavimenti abbinato a un potente motore da 28.000 Pa e a bracci esterni che si estendono: queste, e molte altre, le caratteristiche tecniche di Z60 Ultra Roller Complete, l'ultimo robot di Mova che pulisce secondo le nostre preferenze oppure lasciando far tutto alla ricca logica di intelligenza artificiale integrata
Renault Twingo E-Tech Electric: che prezzo!
Renault Twingo E-Tech Electric: che prezzo!
Renault annuncia la nuova vettura compatta del segmento A, che strizza l'occhio alla tradizione del modello abbinandovi una motorizzazione completamente elettrica e caratteristiche ideali per i tragitti urbani. Renault Twingo E-Tech Electric punta su abitabilità, per una lunghezza di meno di 3,8 metri, abbinata a un prezzo di lancio senza incentivi di 20.000€
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-11-2008, 22:59   #1
marco83pt
Senior Member
 
L'Avatar di marco83pt
 
Iscritto dal: May 2005
Città: Montecatini terme
Messaggi: 309
[C] - Programma gioco del cavallo di eulero!!!

Qualcuno conosce questo rompicato matematico?
E' tratta di far percorrere un intera scacchiera 8x8 ad un cavallo (mossa ad L), toccando una sola volta ogni singola casella. E' giorni che sto impazzendo per fare un programma in C che accetti in ingresso la casella di partenza, e mi dia come output la sequenza di mosse...
Ho provato ad usare la tecnica della Ricorsione ed con un ciclio for...che quando trova una strada bloccata torna indietro finche non prova una seconda via libera...
ma il programma mi "blocca" quando trova la via cieca e mi tira fuori dei risultati insensati...

qualcuno ha un programma in C che faccia questo lavoro, almeno da prendere per spunto.

Grazie, Saluti, Marco.
__________________
Asus M2N-SLI DELUXE - Athlon 64 X2 4600+ - 2x1GB Corsair XMS2 PC6400 - ATI HD3650 - 2x250GB SATA2 RAID-0
marco83pt è offline   Rispondi citando il messaggio o parte di esso
Old 17-11-2008, 23:26   #2
Gregory_House
Senior Member
 
L'Avatar di Gregory_House
 
Iscritto dal: Sep 2007
Città: Roma
Messaggi: 362
Ciao, prova a effettuare una marcatura delle caselle già visitate ed ad utilizzare la tecnica del backtracking, di modo che se capiti in un vicolo cieco torni automaticamente all'ultimo punto in cui hai effettuato una scelta e da li scegli un'altra via.
__________________
CASE: Aerocool QS200 | MOBO: Asrock K10N78 FullHD hSLI | CPU: Phenom II X2 560 BE Core Callisto | RAM: 2x2GB DDRII 800 TeamGroup Elite 5-5-5-15 | SCHEDA VIDEO: Sapphire HD7750 1GB GDDR5 | HARD DISK: Western Digital Caviar Blue 500GB Sata2 | ALI: Enermax Liberty 620W | LCD: Philips 247ELPH 24" | LAPTOP: MacBook Air Mid - 2013 Intel Core i7
Gregory_House è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2008, 13:15   #3
marco83pt
Senior Member
 
L'Avatar di marco83pt
 
Iscritto dal: May 2005
Città: Montecatini terme
Messaggi: 309
Purtroppo le mie conoscenze di C non sono molto evolute, e non conosco la tecnica "tecnica del backtracking". Il problema sta nel fatto che quando torno indietro dalla casella a vicolo chiedo quella mi viene cancellata, mentre la prima ancora no...questo fatto mi sbarella tutto l'agoritmo che ho fatto, poichè vede tale casella come occupata e mi esce del gioco senza darmi una soluzione "esatta".
__________________
Asus M2N-SLI DELUXE - Athlon 64 X2 4600+ - 2x1GB Corsair XMS2 PC6400 - ATI HD3650 - 2x250GB SATA2 RAID-0
marco83pt è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2008, 14:23   #4
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
qua c'è un 3d che avevo aperto io un po di tempo fa.. spero possa esserti utile.. http://www.hwupgrade.it/forum/showthread.php?t=1782141
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2008, 14:54   #5
marco83pt
Senior Member
 
L'Avatar di marco83pt
 
Iscritto dal: May 2005
Città: Montecatini terme
Messaggi: 309
Quote:
Originariamente inviato da ndakota Guarda i messaggi
qua c'è un 3d che avevo aperto io un po di tempo fa.. spero possa esserti utile.. http://www.hwupgrade.it/forum/showthread.php?t=1782141
esatto, sto proprio studiando quel libro.ti ringrazio per la dritta...ci do un'occhiata.
grazie ancora.
__________________
Asus M2N-SLI DELUXE - Athlon 64 X2 4600+ - 2x1GB Corsair XMS2 PC6400 - ATI HD3650 - 2x250GB SATA2 RAID-0
marco83pt è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2008, 15:22   #6
marco83pt
Senior Member
 
L'Avatar di marco83pt
 
Iscritto dal: May 2005
Città: Montecatini terme
Messaggi: 309
ho letto, ti ringrazio per l'aiuto....
ma sto cercando di far percorrere al cavallo l'intera scacchiera.
__________________
Asus M2N-SLI DELUXE - Athlon 64 X2 4600+ - 2x1GB Corsair XMS2 PC6400 - ATI HD3650 - 2x250GB SATA2 RAID-0
marco83pt è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2008, 15:52   #7
marco83pt
Senior Member
 
L'Avatar di marco83pt
 
Iscritto dal: May 2005
Città: Montecatini terme
Messaggi: 309
Quote:
Originariamente inviato da Gregory_House Guarda i messaggi
Ciao, prova a effettuare una marcatura delle caselle già visitate ed ad utilizzare la tecnica del backtracking, di modo che se capiti in un vicolo cieco torni automaticamente all'ultimo punto in cui hai effettuato una scelta e da li scegli un'altra via.
Qualcuno mi può indicare una guida per la tecnica backtracking???
__________________
Asus M2N-SLI DELUXE - Athlon 64 X2 4600+ - 2x1GB Corsair XMS2 PC6400 - ATI HD3650 - 2x250GB SATA2 RAID-0
marco83pt è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2008, 17:34   #8
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Potrebbe interessarti questo articolo?
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2008, 18:54   #9
marco83pt
Senior Member
 
L'Avatar di marco83pt
 
Iscritto dal: May 2005
Città: Montecatini terme
Messaggi: 309
Ora do un occhiata all'articolo.
Il mio dilemma è questo.


Quando torno indietro nelle prove (utilizzando la ricorsività delle funzioni), perdo le informazioni sulle caselle visitate, poichè se una iterazione è nulla devo cancellare le caselle fino al punto dove ho una scelta multipla.
Se creo una matrice Nx2 ci salvo le informazioni per ogni passo, ma poi indice che mi tiene conto del passo mi si modifica, e non posso più sapere la tot posizione a che indice corrisponde.
__________________
Asus M2N-SLI DELUXE - Athlon 64 X2 4600+ - 2x1GB Corsair XMS2 PC6400 - ATI HD3650 - 2x250GB SATA2 RAID-0
marco83pt è offline   Rispondi citando il messaggio o parte di esso
Old 19-11-2008, 00:50   #10
marco83pt
Senior Member
 
L'Avatar di marco83pt
 
Iscritto dal: May 2005
Città: Montecatini terme
Messaggi: 309
Finalmente la soluzione....
spero chi si vuole divertira mi possa correggere qualche inesattezza...
comunque funziona.

Quote:
Originariamente inviato da marco83pt Guarda i messaggi

#include <stdio.h>
#define SIZE 8
void matrixp (int f[ SIZE ][ SIZE ]); // scrittura a video della board
int ct (int board[ SIZE ][ SIZE ]); // ct:controllo terminazione
int cn (int board[ SIZE ][ SIZE ]); // cn:controllo numeri
int cp (int board[ SIZE ][ SIZE ],int rc,int cc); // cp: controllo di passo
void tt (int board[ SIZE ][ SIZE ],int rc,int cc,int p); // tt: trova totale (funzione principale)
int hor[ 8 ] = { 2 , 1 , -1 , -2 , -2 , -1 , 1 , 2 }; //vettore mosse orizzontali
int ver[ 8 ] = { -1 , -2 , -2 , -1 , 1 , 2 , 2 , 1 }; //vettore mosse verticali
int main() {
int board[ SIZE ][ SIZE ] = {{ 0 },{ 0 }};
int rc,cc;
rc = 1;
cc = 1;
board[ rc ][ cc ] = 1;
tt(board,rc,cc,1);
matrixp(board);
return (0);
}
int ct (int board[ SIZE ][ SIZE ]) {
int i,j,e;
e = 0;
for(i = 0;i < SIZE; ++i) {
for(j = 0;j < SIZE; ++j) {
if(board[ j ][ i ] == 0)
e = 1;
}
}
return(e); // e=1 INCOMPLETA ; e=0 COMPLETA
}
int cn (int board[ SIZE ][ SIZE ]) {
int i,j,n;
n = 0;
for(i = 0;i < SIZE; ++i) {
for(j = 0;j < SIZE; ++j) {
if(board[ j ][ i ] != 0)
++n;
}
}
return(n);
}

int cp(int board[ SIZE ][ SIZE ],int rc,int cc) {
int e = 1;
if(rc < SIZE && rc >= 0 && cc < SIZE && cc >= 0 && board[ rc ][ cc ] == 0) {
e = 0;
}
return(e); // e=1 NEGATO ; e=0 CONSENTITO
}
void matrixp (int f[ SIZE ][ SIZE ]){
int i,j;
for(i = 0;i < SIZE; ++i) {
for(j = 0; j < SIZE; ++j) {
printf("%d\t",f[ i ][ j ]);
if(j == SIZE - 1)
printf("\n");
}
}
} // restituisce a video la board
void tt (int board[ SIZE ][ SIZE ], int rc, int cc,int p) {
int r,trc,tcc,tp;
tp = p;
for(r = 0;r < 8; ++r) {
trc = rc + ver[ r ];
tcc = cc + hor[ r ];
if(cp(board,trc,tcc) == 0) {
board[ trc ][ tcc ] = ++p;
if(p == 64)
break;
tt(board,trc,tcc,p);
}
if(r == 7) {
board[ rc ][ cc ] = 0;
}
p = tp;
}
}
__________________
Asus M2N-SLI DELUXE - Athlon 64 X2 4600+ - 2x1GB Corsair XMS2 PC6400 - ATI HD3650 - 2x250GB SATA2 RAID-0
marco83pt è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare Cineca inaugura Pitagora, il supercomputer Lenov...
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA Mova Z60 Ultra Roller Complete: pulisce bene gra...
Renault Twingo E-Tech Electric: che prezzo! Renault Twingo E-Tech Electric: che prezzo!
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l'infrast...
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
I nuovi iPhone 18 Pro potrebbero present...
Una parte dei Galaxy S26 avrà chi...
Amazon permetterà agli autori ind...
Il caso Zuckerberg a Palo Alto: una scuo...
Texas contro Roblox: il procuratore gene...
Offerte auto da urlo su Amazon: da CarPl...
Windows 11 26H1 in arrivo fra pochi mesi...
Un Black Friday continuo a rilascio lent...
Redmi Pad Pro da 12,1" 2560x2600 pi...
Tesla Roadster rinviata (di nuovo): ora ...
Il nuovo TV premium 2025 Samsung OLED 4K...
Ecco una TV QLED da 55'' che costa 303€:...
Doppia offerta per le soundbar Samsung: ...
Nubia Z80 Ultra con Snapdragon 8 Elite G...
Google Pixel, è svendita di tutti...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 16:45.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v