|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
Esercizio C
salve, sto studiando le basi di C, essendomi ritrovato per caso in questo forum qualche ora fa ho deciso di chiedere qua per un aiutino
il seguente algo dovrebbe leggere due stringhe composte da tot caratteri, in questo caso 10, e costruirne una terza concatenandole in ordine alfabetico per poi stampare quest'ultima. Ho copiato l'intero programma dal libro dal quale sto studiando, provando a farlo girare sul web compiler che uso per esercitarmi che ho trovato su repl.it Il risultato però è strano: semplicemente incolla una parte della prima stringa subito dopo la seconda. Insomma, non credo faccia quello che è descritto sopra (che a dire il vero non ho capito esattamente cosa dovrebbe fare, la descrizione è un po ambigua). Non so se per un errore del libro o una diversa versione/implementazione del compilatore. Help? thanks #include <stdio.h> #define LunghezzaArray 10 int main() { int i,j,k; char TempCar; char Array1[LunghezzaArray], Array2[LunghezzaArray]; char ArrayConc[LunghezzaArray * 2]; i=0; while (i<LunghezzaArray) { scanf("%c",&TempCar); Array1[i]=TempCar; i=i+1; } i=0; while(i<LunghezzaArray) { scanf("%c",&TempCar); Array2[i]=TempCar; i=i+1; } i=0; while (i<LunghezzaArray && Array1[i]==Array2[i]) i=i+1; if (i==LunghezzaArray || Array1[i]<Array2[i]) { k=0; j=0; while (j<LunghezzaArray) { ArrayConc[k]=Array1[j]; k=k+1; j=j+1; } j=0; while (j<LunghezzaArray) { ArrayConc[k]=Array2[j]; k=k+1; j=j+1; } } else { k=0; j=0; while (j< LunghezzaArray) { ArrayConc[k]=Array2[j]; k=k+1; j=j+1; } j=0; while (j<LunghezzaArray) { ArrayConc[k]=Array1[j]; k=k+1; j=j+1; } } k=0; while (k<(LunghezzaArray*2)){printf("%c",ArrayConc[k]); k=k+1;} } |
|
|
|
|
|
#2 |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
#include <stdio.h>
#define LunghezzaArray 10 int main() { int i,j,k; char TempCar; char Array1[LunghezzaArray], Array2[LunghezzaArray]; /* Nella seguente dichiarazione il valore LunghezzaArray*2 è un valore costante calcolato a tempo di compilazione*/ char ArrayConc[LunghezzaArray * 2]; /* Legge la prima stringa assicurandosi che essa non superi la dimensione dell'array, 10 caratteri*/ i=0; while (i<LunghezzaArray) /* Si ricordi che il valore dell'indice di un array di LunghezzaArray elementi è compreso fra 0 e LunghezzaArray-1*/ { scanf("%c",&TempCar); Array1[i]=TempCar; i=i+1; } /*Legge la seconda stringa assicurandosi che essa no nsuperi la dimensione dell'array, 10 caratteri*/ i=0; while(i<LunghezzaArray) { scanf("%c",&TempCar); Array2[i]=TempCar; i=i+1; } /*Confronta le due stringhe per capire quale precede l'altra in ordine alfabetico*/ i=0; while (i<LunghezzaArray && Array1[i]==Array2[i]) i=i+1; if (i==LunghezzaArray || Array1[i]<Array2[i]) /*Le due stringhe sono uguali o la prima precede la seconda in ordine alfabetico*/ { k=0; j=0; while (j<LunghezzaArray) { ArrayConc[k]=Array1[j]; k=k+1; j=j+1; } j=0; while (j<LunghezzaArray) { ArrayConc[k]=Array2[j]; k=k+1; j=j+1; } } else /* Se la seconda stringa precede la prima in ordine alfabetico, ossia se (Array2[i]<Array1[i])*/ { k=0; j=0; while (j< LunghezzaArray) { ArrayConc[k]=Array2[j]; k=k+1; j=j+1; } j=0; while (j<LunghezzaArray) { ArrayConc[k]=Array1[j]; k=k+1; j=j+1; } } /*Stampa la stringa ottenuta dalla concatenazione*/ k=0; while (k<(LunghezzaArray*2)){printf("%c",ArrayConc[k]); k=k+1;} } |
|
|
|
|
|
#3 |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
|
|
|
|
|
|
#4 | |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
Quote:
https://repl.it/repls/LongMenacingNumbers |
|
|
|
|
|
|
#5 | |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
Quote:
ma ti restituisce questo risultato con questo compilatore ?? |
|
|
|
|
|
|
#6 | |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
Quote:
e perché se scrivo ste 2 stringhe mi ridà quella li ? non dovrebbe riorganizzare ogni cella in ordine alfabetico ? tra l'altro ne manca una, sono 19 e non 20 http://take.ms/AqyKJ cioè pensavo che il risultato dovesse essere che per ogni cella del terzo array mettesse in ordine le prime 2....in questo modo semplicemente incolla una stringa dietro l'altra, mangiandosi una lettera |
|
|
|
|
|
|
#7 | |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
Quote:
Cioè mi tratta le stringhe come fossero un'unica parola, quindi mette in ordine alfabetico a partire esclusivamente dalla prima lettera...non ordina cella per cella....tutto sto popò di codice per fare semplicemente sta cosa ? |
|
|
|
|
|
|
#8 | |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
Quote:
|
|
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Aug 2017
Messaggi: 469
|
|
|
|
|
|
|
#10 |
|
Junior Member
Iscritto dal: Aug 2018
Messaggi: 9
|
si, ti confermo che ho raggiunto il capitolo che tratta le strutture di controllo e introduce di volta in volta le varie istruzioni cicliche, quell'algo è stato riproposto in modo più "ordinato"
ora però sto avendo problemi con l'ambiente di sviluppo, quel compiler online mi da un sacco di problemi, dovrei scaricare qualcosa di più pratico e completo, in locale. Mi faccio una ricerca su google e trovo una soluzione, grazie ancora Ultima modifica di doublefloat : 03-09-2018 alle 00:03. |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 05:12.




















