Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
be quiet! debutta nel settore mouse da gaming con Dark Perk Ergo e Dark Perk Sym: due modelli gemelli per specifiche, con polling rate di 8.000 Hz anche in wireless, sensore PixArt PAW3950 da 32.000 DPI e autonomia dichiarata fino a 110 ore. Nel test, a 8.000 Hz si arriva a circa 30 ore reali, con ricarica completa in un'ora e mezza
Tutti gli articoli Tutte le news

Vai al Forum
Discussione Chiusa
 
Strumenti
Old 08-02-2011, 17:43   #1
zztop99
Junior Member
 
Iscritto dal: Nov 2010
Messaggi: 6
funzione con struct e puntatori

Ciao,stavo cercando di risolvere questo esercizio,tuttavia dopo infiniti tentativi di farlo girare correttamente non ne sono venuto ancora a capo. Sapreste perfavore indicarmi dove sto sbagliando? Grazie 1000
L'esercizio è questo
Quote:
Definire un tipo di dato ST, struct con due campi di nome A di tipo int e B di tipo vettore di 100 double. Scrivere una funzione con un parametro x di tipo puntatore (riferimento) ad un elemento di tipo ST. La funzione deve inserire nel campo A dell’area di memoria puntata da x la posizione del più piccolo elemento contenuto nel campo B dell’area di memoria puntata da x.
Posto la funzione che ho scritto che è quella che mi da problemi,se riusciste a darmi una mano con questi puntatori mi sareste di grande aiuto


Codice:
#include<stdio.h>
#include<stdlib.h>
#define d 100
typedef struct {int A;int B[d];}ST;

void C(int *x){
     int i,minimo,posizione=-1;
     minimo=x->B[0];
     for(i=1;i<d;i++)
     if(x->B[i]<x->B[0]){
     minimo=B[i];}
     if(minimo){
                posizione=i;
                }
     
     x->A=posizione;
     }
zztop99 è offline  
Old 08-02-2011, 19:14   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12936
Ci sono degli errori nel codice, il testo dice che il vettore dovrebbe essere di 100 elementi di double, tu lo fai di int.

In secondo luogo il puntatore che passi nella funzione dev'essere del tipo ST, e non int.

Comunque anche il codice all'interno non mi sembra corretto, non si capisce perché nel for confronti tutti gli elementi con il primo, anziché con il minimo.
WarDuck è offline  
Old 08-02-2011, 19:55   #3
zztop99
Junior Member
 
Iscritto dal: Nov 2010
Messaggi: 6
Sì avevo messo int al posto di double solo per non incasinarmi di più nel farlo girare. Come faccio a confrontare i valori con il minimo se non so qual è il minimo? Avevo pensato di attribuire il valore minimo al primo e poi lo confronto con gli altri.

Codice:
typedef struct {int A;double B[d];}ST;

void C(ST *x){
 int i,posizione=-1;
double minimo;
     minimo=x->B[0];
     for(i=1;i<d;i++)
     if(x->B[i]< minimo){
     minimo=B[i];}
     if(minimo){
                posizione=i;
                }
     
     x->A=posizione;
     }
Così,forse dovrebbe esserci qualche errore in meno,tuttavia non mi funziona.
zztop99 è offline  
Old 08-02-2011, 21:30   #4
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12936
Premesso che dovresti indentare meglio il codice, in particolare sarebbe meglio che il for avesse le parentesi graffe, comunque c'è un errore nella riga in cui fai:

Codice:
minimo = B[i]
che invece dovrebbe essere chiaramente:
Codice:
minimo = x->B[i]
.

Comunque sarebbe meglio che postassi direttamente gli errori che hai, anche perché queste sono cose che di sicuro il compilatore ti dice e che puoi correggere da solo.

Dopo il ciclo for, quando fai:

Codice:
if (minimo) ...
Dovresti sostituire con:
Codice:
if (minimo >= 0) ...
Se poi posti anche il MAIN sarebbe meglio .
WarDuck è offline  
Old 08-02-2011, 22:24   #5
zztop99
Junior Member
 
Iscritto dal: Nov 2010
Messaggi: 6
Adesso il programma perlomeno gira,tuttavia non funziona ancora come dovrebbe,cioè non mi segna la posizione corretta.

Codice:
#include<stdio.h>
#include<stdlib.h>
#define d 5
typedef struct {int A;double B[d];}ST;

void C(ST *x){
 int i,posizione=-1;
double minimo;
     minimo=x->B[0];
     for(i=1;i<d;i++){
     if(x->B[i]< minimo){
     minimo=x->B[i];}
     if(minimo>=0){
                posizione=i;
                }
                }
     x->A=posizione;
     }
     
    int main ()
    {
        
        ST N;
        int j;
        for(j=0;j<d;j++){
                         scanf("%lf",&N.B[j]);
                         }
        
        C(&N);
        
        printf("%d\n",N.A);
        
        system("pause");
        return 0;
        }
zztop99 è offline  
Old 09-02-2011, 15:15   #6
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12936
Prova ad arrivarci da solo, nel senso che a te interessa sapere la posizione del minimo, solo che questa posizione logicamente può cambiare ad ogni passo del ciclo, in particolare pensa a quando cambia e a quel punto aggiorni la posizione di conseguenza.

Come suggerimento, allo stato attuale, non ti dovrebbe servire affatto controllare che il minimo sia >= 0.
WarDuck è offline  
Old 09-02-2011, 19:07   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
cionci è offline  
 Discussione Chiusa


Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
SpaceX realizzerà uno smartphone ...
Fire TV Omni QLED, Serie 2 e Serie 4: le...
Con l'Event Horizon Telescope si sta stu...
Milano Cortina 2026, dietro le quinte de...
IA e automazione: le armi per industrial...
SpaceX sta per rimuovere il braccio di a...
Sony a ISE 2026: display, soluzioni imme...
Sony punta sull'IA: brevettati i podcast...
Logitech G Astro A50, le cuffie gaming d...
Lenovo a ISE 2026: smart collaboration, ...
GeForce RTX 5000 SUPER cancellate e RTX ...
Substack conferma violazione: esposti da...
L'IA costa caro. Oracle punta a raccogli...
OpenAI lancia Frontier: il cervello cent...
Questo robot aspirapolvere lava sempre c...
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:19.


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