Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
La PNY GeForce RTX 5080 Slim OC si distingue nel panorama delle GPU di fascia alta per il design compatto a due slot, ispirato alla NVIDIA GeForce RTX 5080 Founders Edition. In questo test analizziamo comportamento termico e prestazioni in gioco, valutando se il formato ridotto comprometta o meno l'esperienza complessiva rispetto alle soluzioni più ingombranti presenti sul mercato.
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-09-2012, 01:13   #1
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
[C++] problema cardinalità crescente simmetrica (ricorsiva)

Ciao a tutti..
ho provato a svolgere questo esercizio ma non ci riesco... posso spiegarvi cosa non so fare e magari mi date un consiglio su come farlo?:
allego la traccia dell'esercizio..ho dovuto ridurre le dimensioni per questioni di spazio qui sul forum... ingranditela..

Riesco a trovare la cardinalità centrale...cioè parto dal centro (n/2-1) e se i numeri a sinistra e a destra sono uguali a n/2-1 incremento un contatore (sarebbe la cardinalità);
mi blocco qua..come faccio a vedere la cardinalità di s2 e s4 (sarebbero l'insieme di sinistra e destra rispetto a quello al centro)?
poi vabbè alla fine devo confrontare le cardinalità di s2 e s4 e se sono diverse restituisco false.

Immagini allegate
File Type: png 2.png (24.3 KB, 20 visite)

Ultima modifica di mistergks : 05-09-2012 alle 14:57.
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2012, 02:26   #2
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Ho caricato la traccia su:
http://depositfiles.com/files/ngs9fs60o">http://depositfiles.com/files/ngs9fs60o

Inviato dal mio GT-I9003 usando Tapatalk
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2012, 04:54   #3
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da mistergks Guarda i messaggi
Ho caricato la traccia su:
http://depositfiles.com/files/ngs9fs60o">http://depositfiles.com/files/ngs9fs60o

Inviato dal mio GT-I9003 usando Tapatalk
Perdonami ma con tutta la buona volonta' che uno ci puo' mettere non si riesce a leggere nulla, o quasi. Magari puoi provare a descrivere la traccia, o scannerizzarla con una risoluzione migliore.....
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2012, 11:12   #4
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Delete

Ultima modifica di mistergks : 05-09-2012 alle 14:55.
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2012, 14:55   #5
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Traccia:
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2012, 17:05   #6
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Up

Inviato dal mio GT-I9003 usando Tapatalk
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2012, 20:08   #7
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Una soluzione potrebbe essere la seguente (ovviamente l'entry point e' la funzione doCheck()):

Codice:
bool getMiddleCount(int *vect, int n, int &lowIndex, int &highIndex)
{
    if (lowIndex <= 0)
        return true;
    if (vect[lowIndex] != vect[highIndex])
	{
		lowIndex++;
		highIndex--;
		return lowIndex <= highIndex;
	}
    return getMiddleCount(vect, n, --lowIndex, ++highIndex);
}

bool checkEquals(int *vect, int startIndex, int endIndex)
{
    if (startIndex == endIndex)
        return true;
    return (vect[startIndex] == vect[endIndex]) && checkEquals(vect, startIndex+1, endIndex);
}

bool doCheckLeftIncreasingCount(int *vect, int count, int startIndex, int endIndex)
{
    if (endIndex <= startIndex) /* Base of recursion */
        return true;
	if (!checkEquals(vect, endIndex-count, endIndex))
        return false;
    count++;
    return doCheckLeftIncreasingCount(vect, count, startIndex, endIndex-count);
}

bool doCheckRightIncreasingCount(int *vect, int count, int startIndex, int endIndex)
{
    if (endIndex <= startIndex) /* Base of recursion */
        return true;
	if (!checkEquals(vect, startIndex, startIndex+count))
        return false;
    count++;
    return doCheckRightIncreasingCount(vect, count, startIndex+count, endIndex);
}

bool doCheck(int *vect, int n)
{
    int lowIndex, highIndex;
    lowIndex = highIndex = n/2;
    if (!getMiddleCount(vect, n, lowIndex, highIndex)) return false;
    if (lowIndex <= 0)
        return true;        /* The whole array is filled up with the same number */
    if (doCheckLeftIncreasingCount(vect, highIndex-lowIndex+1, 0, lowIndex-1))
        return doCheckRightIncreasingCount(vect, highIndex-lowIndex+1, highIndex+1, n-1);
	return false;
}


int main()
{
    int vect[21] = { 1,1,1,1,1,2,2,2,2,3,3,3,4,4,4,4,5,5,5,5,5 };
    bool res = doCheck(vect, (int)(sizeof(vect)/sizeof(int)));
    printf ("Result: %s\n", res ? "OK" : "ERROR");

    return 0;
}
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 08-09-2012, 00:10   #8
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Una soluzione potrebbe essere la seguente (ovviamente l'entry point e' la funzione doCheck()):

Codice:
bool getMiddleCount(int *vect, int n, int &lowIndex, int &highIndex)
{
    if (lowIndex <= 0)
        return true;
    if (vect[lowIndex] != vect[highIndex])
	{
		lowIndex++;
		highIndex--;
		return lowIndex <= highIndex;
	}
    return getMiddleCount(vect, n, --lowIndex, ++highIndex);
}

bool checkEquals(int *vect, int startIndex, int endIndex)
{
    if (startIndex == endIndex)
        return true;
    return (vect[startIndex] == vect[endIndex]) && checkEquals(vect, startIndex+1, endIndex);
}

bool doCheckLeftIncreasingCount(int *vect, int count, int startIndex, int endIndex)
{
    if (endIndex <= startIndex) /* Base of recursion */
        return true;
	if (!checkEquals(vect, endIndex-count, endIndex))
        return false;
    count++;
    return doCheckLeftIncreasingCount(vect, count, startIndex, endIndex-count);
}

bool doCheckRightIncreasingCount(int *vect, int count, int startIndex, int endIndex)
{
    if (endIndex <= startIndex) /* Base of recursion */
        return true;
	if (!checkEquals(vect, startIndex, startIndex+count))
        return false;
    count++;
    return doCheckRightIncreasingCount(vect, count, startIndex+count, endIndex);
}

bool doCheck(int *vect, int n)
{
    int lowIndex, highIndex;
    lowIndex = highIndex = n/2;
    if (!getMiddleCount(vect, n, lowIndex, highIndex)) return false;
    if (lowIndex <= 0)
        return true;        /* The whole array is filled up with the same number */
    if (doCheckLeftIncreasingCount(vect, highIndex-lowIndex+1, 0, lowIndex-1))
        return doCheckRightIncreasingCount(vect, highIndex-lowIndex+1, highIndex+1, n-1);
	return false;
}


int main()
{
    int vect[21] = { 1,1,1,1,1,2,2,2,2,3,3,3,4,4,4,4,5,5,5,5,5 };
    bool res = doCheck(vect, (int)(sizeof(vect)/sizeof(int)));
    printf ("Result: %s\n", res ? "OK" : "ERROR");

    return 0;
}
Non riesco a capire il codice..forse perchè è proprio in stile c..
Puoi spiegarmi passo per passo? Pero il tutto deve essere fatto in una sola funzione!

Inviato dal mio GT-I9003 usando Tapatalk
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 08-09-2012, 21:20   #9
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Certo che posso spiegarti. Pero' dal testo non ho dedotto che il tutto debba essere fatto in una sola funzione. Anche perche', quand'anche possibile, sarebbe davvero un'impresa non da poco.
Secondo me il fatto che abbiano scritto "scrivere una funzione che..." non esclude il fatto che possa crearne altre, da essa chiamate, per semplificarmi il lavoro, no? Specialmente quanto si parla di ricorsivita'!

Ad ogni modo:
- bool getMiddleCount(int *vect, int n, int &lowIndex, int &highIndex);
dato il vettore e la sua lunghezza, determina l'ampiezza della sequenza centrale, che deve essere simmetrica rispetto al centro. Se tale simmetria viene a mancare, ritorna false. Altrimenti ritorna true e lowIndex, highIndex contengono i due indici che delimitano detta zona. Ovviamente l'implementazione e' ricorsiva.

- bool checkEquals(int *vect, int startIndex, int endIndex)
Controlla che tutti gli elementi del vettore vect da startIndex a endIndex siano uguali e ritorna true se lo sono. L'implementazione e' ricorsiva, anche se quella iterativa sarebbe stata banale.

- bool doCheckLeftIncreasingCount(int *vect, int count, int startIndex, int endIndex)
Controlla che gli intervalli a sinistra dell'intervallo centrale siano di dimensione crescente, come richiesto. Implementazione ricorsiva.

- bool doCheckRightIncreasingCount(int *vect, int count, int startIndex, int endIndex)
Come sopra, ma si muove a destra.

doCheck() e' la funzione principale, che deve solo chiamare le funzioni di cui sopra per fare il "dirty job"

Prova a rileggerle sapendo cosa devono fare. Ovviamente se ti servono piu' informazioni saro' felice di provvedere; preferirei delle domande precise su un particolare dell'implementazione....
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Fiber to the Office, sicurezza cyber e f...
Stop improvviso per la serie TV di Tomb ...
Geely unifica R&D tra Svezia e Germania:...
Antec e Noctua insieme: nasce il Flux Pr...
L'Unione Europea contro le app che gener...
Quale sarà il prezzo di PS6? Indi...
Economico, potente e capiente: l'archite...
La Hongguang Mini EV è impossibil...
Wi-Fi 7 in ogni angolo di casa: FRITZ!Re...
Viaggio all'interno di Orfeo, il data ce...
The Pirate Bay immortale: il torrent più...
E-bike Engwe esagerate: con le offerte d...
Stop alla tassa sui pacchi low-cost: ecc...
Nuovi occhiali AI Ray-Ban Meta: focus su...
Nuovi memristori in ossido di afnio: Cam...
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: 13:38.


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