Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
ASUS Expertbook PM3: il notebook robusto per le aziende
ASUS Expertbook PM3: il notebook robusto per le aziende
Pensato per le necessità del pubblico d'azienda, ASUS Expertbook PM3 abbina uno chassis particolrmente robusto ad un pannello da 16 pollici di diagonale che avantaggia la produttività personale. Sotto la scocca troviamo un processore AMD Ryzen AI 7 350, che grazie alla certificazione Copilot+ PC permette di sfruttare al meglio l'accelerazione degli ambiti di intelligenza artificiale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-07-2011, 01:10   #1
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
[C++] array multidimensionale: come ragionare..

Questo è parte dell'esercizio su cui ho problemi:
si implementi una funzione booleana che restituisca true se la condizione è verificata, false altrimenti.
La funzione riceve come parametro una matrice di numeri interi di dimensione n*m; si attende in essa una striscia di demarcazione che la separa in due parti. Questa striscia risulta costituita da elementi vicini pari a "0"; essa consente di individuare una regione superiore e una inferiore, nella matrice stessa. Si noti che per elementi vicini si intendono due elementi presenti in due colonne consecutive e su righe che differiscono al piu di uno(quindi sulla stessa riga o su due righe consecutive). La funzione richiesta deve restituire true se la differenza tra l'elemento minimo e quello massimo della regione superiore è pari al valore medio tra gli elementi della regione inferiore. NOTA: sia la parte superiore che quella inferiore contengono almeno un elemento per ciascuna colonna(questo vuol dire che gli zeri non possono mai trovarsi sulla prima riga o sull'ultima). Inoltre, si può considerare la media degli elementi nella regione inferiore approssimata all'intero inferiore.
ESEMPIO:
matrice:
Codice:
5 7 3 2 2 7 8 5 8
0 3 5 4 6 0 0 5 4
6 0 0 7 0 9 9 0 6
7 4 5 0 4 2 5 7 0
3 4 8 7 5 9 4 9 9
nella matrice riportata sopra la differenza tra gli elemetni massimo e minimo della parte superiore è pari a 8-2=6. la media dei valori nella regione inferiore è pari a 116/19=6,1 che approssimato all'intero inferiore fa 6. La funzione dovrà restituire "true".


Il mio problema generale è: come devo ragionare con questo tipo di esercizi?
In particolare con questo: come faccio a fare la somma solo sulla regione inferiore? cioè che condizione devo usare per dividere le due regioni in base agli zeri? Non riesco proprio a metterlo giu' sto esercizio...qualcuno mi dà l'input giusto per iniziare a fare qualcosa? Non chiedo di svolgerlo per intero...
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2011, 12:36   #2
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
nessuno sa aiutarmi?
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2011, 13:29   #3
AngeL)
Senior Member
 
L'Avatar di AngeL)
 
Iscritto dal: May 2006
Città: Salerno
Messaggi: 936
Se gli unici elementi pari a 0 sono quelli del separatore, puoi leggere la matrice dall'alto verso il basso e da sinistra verso destra, e considerare, per ogni colonna, gli elementi trovati prima di uno 0 come facenti parte della regione superiore e gli altri della regione inferiore; a questo punto di quelli sopra cerchi massimo e minimo, di quelli sotto fai la somma e il conto e poi calcoli la media. Puoi anche leggere tutta la matrice in una botta sola:

Codice:
for(int i = 0; i < m; i++) {
    int j = 0;
    while(mat[i][j] != 0) {
        if(mat[i][j] > max_upper)
            max_upper = mat[i][j];
        else if(mat[i][j] < min_upper)
            min_upper = mat[i][j];
        j++;
    }
    //ora sei nella parte inferiore
    j++; // scarti lo 0
    while(j < n) {
        tot_lower += mat[i][j];
        count_lower++;
        j++;
    }
}
AngeL) è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2011, 13:32   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2780
Secondo me la cosa migliore è ragionare colonna per colonna: se vuoi fare calcoli sulla zona inferiore parti dal basso e ti fermi quando trovi lo zero, viceversa se vuoi fare calcoli sulla zona superiore parti dall'alto.
L'unico dubbio è: c'è un solo 0 per ogni colonna? Dalla traccia non l'ho capito, anche se suppongo di sì perché altrimenti l'esercizio sarebbe molto più complicato.
wingman87 è online   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 16:33   #5
salvo19881
Junior Member
 
Iscritto dal: Oct 2010
Messaggi: 19
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Secondo me la cosa migliore è ragionare colonna per colonna: se vuoi fare calcoli sulla zona inferiore parti dal basso e ti fermi quando trovi lo zero, viceversa se vuoi fare calcoli sulla zona superiore parti dall'alto.
L'unico dubbio è: c'è un solo 0 per ogni colonna? Dalla traccia non l'ho capito, anche se suppongo di sì perché altrimenti l'esercizio sarebbe molto più complicato.
il testo non specifica se sono o meno presenti quindi dobbiamo supporre che ci possano essere degli 0 che non fanno parte della linea di demarcazione.
io procederei nel seguente modo.
mi creerei un vetttore (chiamiamolo POSIZIONE) di n elementi(matrice m*n) in cui vado a salvare l'indice corrispondente allo zero(separatore)di ogni colonna.
Per trovare questo scorriamo la matrice da sinistra a destra e dall'alto al basso
quindi partendo dall'elemento [0,0] vado a cercare il valore 0 supponiamo sia in [0,i], salvo i in Posizione[0]
allora vado a vedere se in [1,i-1],[1,i],[1,i+1] c'è uno 0 se si aggiorno la i a i-1,i,i+1 (in base a dove ho trovato lo 0, e salvo la i in posizione[1] e così via.

Ora supponiamo di essere arrivati all'elemento [n.i] in cui vi è uno 0.
se alla colonna n+1 non ci sono 0 compatibili, bisogna tornare alla colonna n e vedere se oltre allo 0 in [n,i] vi siano altri 0 compatibili con la colonna [n-1].

e si procede a ritroso fino a trovare una colonna che abbia altri 0 compatibili(se arriviamo alla prima colonna ovviamente non controlliamo più a ritroso ma scendiamo a cercare altri 0).

Scusa se sono mooolto poco esaudiente nella spiegazione, ma non per niente non sono un prof.
Cmq spero hai capito cosa voglia dire, in caso contrario stasera(quando finisco i miei studi giornalieri) vedo di imprementare un algoritmo x trovarti gli elementi separatori

PS
come non detto mi sono accarto di essere completamente perso su diversi argomenti, quindi considerando che ho l'esame giovedì, mi devo mettere a fare le nottate.
se non hai premura provo a scrivere qualcosa venerdi.

Ultima modifica di salvo19881 : 04-07-2011 alle 19:21. Motivo: rettifica
salvo19881 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design   Recensione OnePlus 15: potenza da vendere e batt...
Black Friday Amazon: la GeForce RTX 5070...
EcoFlow, il Black Friday porta grande ri...
Gli sconti più pesanti del Black ...
Smart #5 BRABUS segna il nuovo record di...
Incentivi auto elettriche 2025, a volte ...
Oura apre una maxi disputa sui brevetti ...
Tre gruppi criminali si uniscono e crean...
BMW iX3: la Neue Klass supera i 1.000 km...
LinusTechTips pensa che Steam Machine do...
Black Friday Amazon: avviatori auto e ac...
Warner e Udio depongono le armi: l'IA di...
Snapdragon 8 Gen 5: il nuovo processore ...
Black Friday OPPO: prezzi a picco su sma...
Arriva il nuovo Amazon Haul per il Black...
Mafia: Terra Madre: arriva il Free Ride ...
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: 15:36.


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