Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-04-2008, 13:23   #1
|_Mayhem_|
Member
 
Iscritto dal: Mar 2008
Messaggi: 47
[c]somma diagonale di un array bidimensionale di 10x10

salve a tutti!

mi è stato assegnato un esercizio a scuola che chiede di:

"riempire un array bidimensionale di 10x10 con numeri da 1 a 10 e calcolare la somma della diagonale"

vi posto il mio codice:

Codice:
#include <stdio.h>

int main(){

int bidimensionale[10][10];
int i,j,somma_diagonale=0;

for(i=0;i<10;i++){

for(j=0;j<10;j++){
bidimensionale[i][j]=j+1;
printf("%d ",bidimensionale[i][j]);
}
printf("\n");
}

printf("\nvalori della diagonale:\n\n");

for(i=0;i<10;i++){

for(j=0;j<10;j++){
                  
if(i=j)
somma_diagonale=somma_diagonale+bidimensionale[i][j];
printf("%d ",bidimensionale[i][j]);
}
}     

printf("\n\nsomma della diagionale: %d\n\n",somma_diagonale);
    
system("PAUSE");
return 0;
}
e l'output:

Codice:
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10

valori della diagonale:

1 2 3 4 5 6 7 8 9 10

somma della diagionale: 54

Press any key to continue . . .
perche 54 la somma quando dovrebbe essere 55??

ho verificato tramite i printf che i valori siano inseriti correttamente nell'array e che nella diagonale siano effettivamente presenti quei valori... dunque c'è qualcosa che va storto nella somma e viene lasciato via -presumibilmente- il primo valore della diagonale, ovvero 1.

che c'è che non va nel codice?
|_Mayhem_| è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2008, 13:44   #2
il_toby
Junior Member
 
Iscritto dal: May 2007
Messaggi: 17
l'errore sta qui:

if(i=j)

per fare un confronto devi usare il doppio uguale, così:

if(i==j)

e per rendere più veloce il codice visto che conosci a priori le dimensioni della matrice, per la somma potresti fare così:

for(i=0;i<10;i++)
{
somma_diagonale=somma_diagonale+bidimensionale[i][i];
printf("%d",bidimensionale[i][i]);
}

invece di

for(i=0;i<10;i++){

for(j=0;j<10;j++){

if(i=j)
somma_diagonale=somma_diagonale+bidimensionale[i][j];
printf("%d ",bidimensionale[i][j]);
}
}

Ultima modifica di il_toby : 27-04-2008 alle 13:48.
il_toby è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2008, 13:49   #3
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Prima un consiglio:
Codice:
somma_diagonale=somma_diagonale+bidimensionale[i][j];
Se lo scrivi così è più leggibile:
Codice:
somma_diagonale += bidimensionale[i][j];
Poi il problema è questo:
Codice:
if(i=j)
Questa è un'assegnazione, in pratica trasferisci il valore di j in i, il confronto lo si fa col doppio uguale:
Codice:
if (i == j)
Come hai scritto tu prima assegna j ad i e poi controlla se il valore è vero (non-zero), che nel caso del primo elemento (0) è falso. Comunque potevi fare più semplicemente con un solo indice:
Codice:
int x;

for (x = 0; x < 10; x++) {
  somma += matrice[x][x];
}
ciao
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2008, 13:56   #4
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
D'oh! Sono stato troppo lento!
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2008, 14:09   #5
|_Mayhem_|
Member
 
Iscritto dal: Mar 2008
Messaggi: 47
grazie, sapevo che era una stupidaggine

mi chiedo però perche faceva comunque la somma degli altri valori... mah, misteri del processore

beh è vero per prendere i numeri dalla diagonale posso usare anche una sola variabile, tanto la diagonale si ha quando il valore delle due variabili si equivale quindi vale la pena usarne una sola!

Ultima modifica di |_Mayhem_| : 27-04-2008 alle 14:12.
|_Mayhem_| è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Aetherflux e Lockheed Martin insieme per...
SpaceX sta proseguendo i test della terz...
Axiom Space ha mostrato un nuovo video d...
Realme: la trasformazione in sub-brand d...
PlayStation 6 si farà attendere: ...
BWT Alpine chiude la prima tornata di pr...
Beyond Good & Evil 2 non è st...
Qualcomm: il CEO ha guadagnato quasi 30 ...
AMD: 'Non importa cosa dice Intel, i mig...
Non è solo colpa del mercato: il ...
3 smartphone ai prezzi più bassi ...
Pwn2Own Automotive 2026 da record: 76 ze...
Più watt, più bassi e subwoofer incluso:...
Xiaomi POCO F8 Pro, un top di gamma a 54...
Tassa di 2 euro sui piccoli pacchi: un a...
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: 07:36.


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