|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Jan 2005
Messaggi: 50
|
un aiuto per due programmi
Ciao ragazzi il 28 ho un esame di elementi di informatica e non riesco a far funzionare correttamente due programmi.
il primo mi dovrebbe compilare un elenco, ma non mi fa inserire il nome il secondo invece mi dovrebbe dire quante volte ho inserito un carattere in una stringa, ma non mi dice quante volte ho inserito il carattere accentati come la ò ,la à, la è.... li metto in allegato, dateci un'occhiata. ciao |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
|
questo è il prog2
Codice:
#include <stdio.h>
#define MAX_LEN 301
int main (void) {
char stringa[MAX_LEN];
int trovato, i, j;
printf("Inserisci una stringa di caratteri\n");
fgets(stringa, MAX_LEN, stdin);
for(j=0;j<256;j++) {
trovato=0;
for(i=0; stringa[i]!='\n'; i++) if(stringa[i]==j) trovato++;
if(trovato!=0)
printf("Il carattere '%c' e' stato trovato il seguente numero di volte: %d \n", j, trovato);
}
return 0;
}
Ultima modifica di VegetaSSJ5 : 24-02-2005 alle 20:14. |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Jun 2002
Città:
Provincia De VaRéSe ~ § ~ Lat.: 45° 51' 7" N Long.: 8° 50' 21" E ~§~ Magica Inter ~ § ~ Detto: A Chi Più Amiamo Meno Dire Sappiamo ~ § ~ ~ § ~ Hobby: Divertimento allo Stato Puro ~ § ~ ~ § ~ You Must Go Out ~ § ~
Messaggi: 8897
|
il primo manco si compila ... adesso lo sto rimettendo a posto ... per il nome lo prendi a caratteri?? why??
istruzioni ua attaccata all'altra ... che ti costa metterle su righe differenti?? ~§~ Sempre E Solo Lei ~§~
__________________
Meglio essere protagonisti della propria tragedia che spettatori della propria vita
Si dovrebbe pensare più a far bene che a stare bene: e così si finirebbe anche a star meglio. Non preoccuparti solo di essere migliore dei tuoi contemporanei o dei tuoi predecessori.Cerca solo di essere migliore di te stesso |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Jun 2002
Città:
Provincia De VaRéSe ~ § ~ Lat.: 45° 51' 7" N Long.: 8° 50' 21" E ~§~ Magica Inter ~ § ~ Detto: A Chi Più Amiamo Meno Dire Sappiamo ~ § ~ ~ § ~ Hobby: Divertimento allo Stato Puro ~ § ~ ~ § ~ You Must Go Out ~ § ~
Messaggi: 8897
|
vabe adesso te lo posto così va modificata una cosa
Codice:
#include <stdio.h>
#include <windows.h>
#define CARD 21
#define NMESI 12
struct elenco {
char nome [CARD];
char cognome [CARD];
int matricola;
int presenze[NMESI];
};
char mesi[][20] = {"Gennaio", "Febbraio", "Marzo", "Aprile", "Maggio", "Giugno", "Luglio", "Agosto", "Settembre", "Ottobre", "Novembre", "Dicembre"};
int main (){
const int cardinalita=300;
int scelta,numero,sommatoria;
struct elenco array[cardinalita];
printf("\nPROGRAMMA PER LA COMPILAZIONE DI UN ELENCO DI STUDENTI\n");
do{
printf("\n\n\nDigitare il valore desiderato\n");
printf("\n1 - Riempire l'elenco\n");
printf("2 - Stampare l'elenco\n");
printf("3 - Uscire dal programma\n");
printf("\nScelta:\t");
do{
scanf("%d",&scelta);
if(scelta<=0||scelta>4)
printf("ERRORE: Il valore immesso non e' presente nel menu'\n");
} while(scelta<=0||scelta>3);
switch(scelta){
case 1: {
printf("Digitare il numero di elementi da inserire: ");
do{
scanf("%d",&numero);
if(numero<0)
printf("ERRORE: Impossibile inserire un numero negativo\n");
if(numero>cardinalita)
printf("Il numero inserito supera la cardinalita dell'elenco.\nPuoi inserire al massimo %d valori.\n",cardinalita);
} while(numero>cardinalita||numero<0);
for(int j=0;j<numero;j++){
fflush (stdin);
printf("Nome:\t");
gets(array[j].nome);
fflush(stdin);
printf("Cognome:\t");
gets(array[j].cognome);
printf("\n\n");
fflush (stdin);
printf("Matricola: ");
scanf("%d",&array[j].matricola);
printf("\n");
printf("Presenze\n");
for (int i=0;i<NMESI;i++){
printf("\t- %s: ",mesi[i]);
scanf("%d",&array[j].presenze[i]);
printf("\n");
}
}
break;
}
case 2:{
if(numero>0){
for(int i=0;i<numero;i++){
printf("Cognome: %s\n",array[i].cognome);
printf("Nome: %s\n",array[i].nome);
printf("Matricola: %d\n",array[i].matricola);
printf("Presenze:\n");
sommatoria = 0;
for (int j=0;j<NMESI;j++){
printf("\t- %s: %d\n",mesi[j],array[i].presenze[j]);
sommatoria=sommatoria+array[i].presenze[j];
}
printf("PRESENZE TOTALI: %d\n",sommatoria);
}
} else
printf("Elenco vuoto. Inserisci il valore 1 per riempirlo\n");
break;
}
}
}while(scelta!=3);
system ("PAUSE");
return (1);
}
__________________
Meglio essere protagonisti della propria tragedia che spettatori della propria vita
Si dovrebbe pensare più a far bene che a stare bene: e così si finirebbe anche a star meglio. Non preoccuparti solo di essere migliore dei tuoi contemporanei o dei tuoi predecessori.Cerca solo di essere migliore di te stesso |
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Jun 2002
Città:
Provincia De VaRéSe ~ § ~ Lat.: 45° 51' 7" N Long.: 8° 50' 21" E ~§~ Magica Inter ~ § ~ Detto: A Chi Più Amiamo Meno Dire Sappiamo ~ § ~ ~ § ~ Hobby: Divertimento allo Stato Puro ~ § ~ ~ § ~ You Must Go Out ~ § ~
Messaggi: 8897
|
non ti modifico il codice che ho postato perchè non so se era quello che volevi ma quando reinserisci 1 sovrascrivi gli elementi già inseriti.
~§~ Sempre E Solo Lei ~§~
__________________
Meglio essere protagonisti della propria tragedia che spettatori della propria vita
Si dovrebbe pensare più a far bene che a stare bene: e così si finirebbe anche a star meglio. Non preoccuparti solo di essere migliore dei tuoi contemporanei o dei tuoi predecessori.Cerca solo di essere migliore di te stesso |
|
|
|
|
|
#6 |
|
Member
Iscritto dal: Jan 2005
Messaggi: 50
|
VegetaSSJ5 questo è il prog2
code:--------------------------------------------------------------------------------#include <stdio.h> #define MAX_LEN 301 int main (void) { char stringa[MAX_LEN]; int trovato, i, j; printf("Inserisci una stringa di caratteri\n"); fgets(stringa, MAX_LEN, stdin); for(j=0;j<256;j++) { trovato=0; for(i=0; stringa[i]!='\n'; i++) if(stringa[i]==j) trovato++; if(trovato!=0) printf("Il carattere '%c' e' stato trovato il seguente numero di volte: %d \n", j, trovato); } return 0; } Vegeta grazie per la risposta ma anche il programma che hai scritto tu non mi dice quante volte compare la è, la à, la ò e la ù. Fenomeno85 il primo manco si compila ... adesso lo sto rimettendo a posto ... per il nome lo prendi a caratteri?? why?? istruzioni ua attaccata all'altra ... che ti costa metterle su righe differenti?? Grazie feno... ma questi programmi li devo presentare ad un esame di elementi di informatica e alcune funzioni non le abbiamo studiate, tipo quelle che hai messo tu(fflush (stdin); gets(array[j].nome);....ecc.) . (il prof c'ha detto che una stringa la possiamo prendere con il comando getchar()...quindi se gli presento altre cose...non credo che vada bene.) Per compilarlo io uso cygwin (shell linux) e quindi con un compilatore per windows non funziona senza modificarlo. |
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Jun 2002
Città:
Provincia De VaRéSe ~ § ~ Lat.: 45° 51' 7" N Long.: 8° 50' 21" E ~§~ Magica Inter ~ § ~ Detto: A Chi Più Amiamo Meno Dire Sappiamo ~ § ~ ~ § ~ Hobby: Divertimento allo Stato Puro ~ § ~ ~ § ~ You Must Go Out ~ § ~
Messaggi: 8897
|
Questi programmi al massimo devono avere problemi solo sulle librerie non per il resto. scusa ma che cosa studiate per quell'esame?? queste son le cose super basilari del c ... cmq se devi per forza pigliare carattere per carattere diventa così:
Codice:
#include <stdio.h>
#include <conio.h>
#include <windows.h>
#define NUM 10
int main (void){
char name [NUM];
int i=0;
while ((name[i] = getchar())!='\n' && i<NUM){
i++;
}
name[i] = '\0';
printf ("\n%s\n\n",name);
system ("PAUSE");
return (0);
}
__________________
Meglio essere protagonisti della propria tragedia che spettatori della propria vita
Si dovrebbe pensare più a far bene che a stare bene: e così si finirebbe anche a star meglio. Non preoccuparti solo di essere migliore dei tuoi contemporanei o dei tuoi predecessori.Cerca solo di essere migliore di te stesso |
|
|
|
|
|
#8 | |
|
Senior Member
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
|
Quote:
Codice:
#include <stdio.h>
#define MAX_LEN 301
int main (void) {
int stringa[MAX_LEN];
int trovato, i, j;
printf("Inserisci una stringa di caratteri\n");
i=0;
while ((stringa[i]= getchar()) != '\n' && i<MAX_LEN) i++;
for(j=0;j<256;j++) {
trovato=0;
for(i=0; stringa[i]!='\n'; i++) if(stringa[i]==j) trovato++;
if(trovato!=0)
printf("Il carattere '%c' e' stato trovato il seguente numero di volte: %d \n", j, trovato);
}
return 0;
}
|
|
|
|
|
|
|
#9 |
|
Member
Iscritto dal: Jan 2005
Messaggi: 50
|
Grazie vegeta....Funziona!
Però non ho capito perchè il programma che ho fatto io non funziona! tu l'hai capito? Fenomeno Non sono io che decido il programma delle materie....sicuramente nel prossimo semestre approfondiremo di più il linguaggio c! Cmq non ho capito a quale programma ti stai riferendo. A me nel primo programma mi interessa solo riuscire ad avere un elenco dove è possibile mettere anche più di un nome o cognome nelle stringhe (cioè che quando do lo spazio non si interrompa la compilazione della stringa e mi legga solo i caratteri messi prima dello spazio). |
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Jun 2002
Città:
Provincia De VaRéSe ~ § ~ Lat.: 45° 51' 7" N Long.: 8° 50' 21" E ~§~ Magica Inter ~ § ~ Detto: A Chi Più Amiamo Meno Dire Sappiamo ~ § ~ ~ § ~ Hobby: Divertimento allo Stato Puro ~ § ~ ~ § ~ You Must Go Out ~ § ~
Messaggi: 8897
|
se guardi i due pezzi di codice e metti il secondo nel primo al posto del gets ... vedresti che la stringa si piglia tutta anche con lo/i spazio/i.
~§~ Sempre E Solo Lei ~§~
__________________
Meglio essere protagonisti della propria tragedia che spettatori della propria vita
Si dovrebbe pensare più a far bene che a stare bene: e così si finirebbe anche a star meglio. Non preoccuparti solo di essere migliore dei tuoi contemporanei o dei tuoi predecessori.Cerca solo di essere migliore di te stesso |
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
|
Quote:
Codice:
#include <stdio.h>
int main (void) {
char c;
printf("Inserisci un numero: ");
scanf("%d", &c);
printf("\nHai inserito il numero %d che corrisponde al carattere %c\n", (int)c, c);
return 0;
}
poi prova a dichiarare c come int (in questo caso non va in crash) e inserisci sempre 137. |
|
|
|
|
|
|
#12 |
|
Member
Iscritto dal: Jan 2005
Messaggi: 50
|
Vegeta hai ragione... funziona anche il programma che avevo fatto io se tratto la stringa come array di interi. Grazie
Feno ancora non ho visto se funziona, ti farò sapere. ciao |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 18:12.



















