|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Sep 2009
Messaggi: 375
|
Semplice esercizio C
Salve, da poco mi sto dedicando ad imparare la programmazione in linguaggio C e a tal proposito ho acquistato il manuale di programmazione "Il Linguaggio C: Principi di programmazione e manuale di riferimento".
Trovo il libro ben strutturato e trovo fare gli esercizi di fine paragrafo molto utile. Tuttavia vi è un esercizio, proprio all'inizio, in cui mi sono bloccato e anche avendoci pensato parecchio proprio non riesco ad arrivare alla soluzione con gli strumenti che mi ha fornito il libro finora. L'esercizio dice: "Si scriva un programma i cui dati in uscita replichino i dati in ingresso, sostituendo però una stringa di uno o più spazi con uno spazio singolo." Ora, io so come ottenere e replicare i dati in ingresso, tuttavia non saprei proprio come eliminare gli spazi in eccesso lasciandone solo uno. La mia idea sarebbe quella di confrontare i caratteri adiacenti ma non so se può funzionare, come l'ho implementato io finora non funziona. Spero qualcuno possa darmi un aiuto (non chiedo la soluzione completa, che mi farebbe comodo, ma anche solo un aiuto nella direzione giusta), gli sarei molto grato. Non usate funzioni complesse dato che ho appena iniziato e conosco molto poco. Grazie in anticipo. |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
|
Beh, prova a spiegare che tipo di logica hai usato nel tuo tentativo di soluzione e posta il codice (usando il tag CODE, che mantiene l'identazione).
Comunque in linea di massima una soluzione che mi viene in mente al volo è quella di scandire l'array di char dato in input e, finchè si legge un carattere diverso da [spazio vuoto] copiare carattere per carattere il contenuto in un nuovo array. Quando si legge uno [spazio vuoto] si consulta un flag: se il flag è alzato si ignora lo [spazio vuoto] letto altrimenti lo si copia; - il flag viene alzato ogni volta che: si legge uno [spazio vuoto] E il flag risulta abbassato; - il flag viene resettato ogni volta che: si legge un carattere diverso da [spazio vuoto].
__________________
As long as you are basically literate in programming, you should be able to express any logical relationship you understand. If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it. (Chris Crawford) |
|
|
|
|
|
#3 | |
|
Moderatore
Iscritto dal: Nov 2006
Messaggi: 21840
|
Quote:
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX) Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000 |
|
|
|
|
|
|
#4 |
|
Junior Member
Iscritto dal: Dec 2006
Messaggi: 8
|
Potresti immagazzinare l'input in una stringa, poi stampare in output la stringa, carattere per carattere, tenendo a mente che una stringa in c è un array di char, considerando che laddove vi siano uno o più spazi si può scorrere l'array fino a che si incontra un carattere che non sia lo spazio che in ogni caso và stampato, in pseudocodice risulterebbe qualcosa di simile a questo:
i = 0; while(string[i] != '\0') if(string[i] == ' ') while(string[i] == ' ') i++; putchar(' '); putchar(string[i]); i++; Ultima modifica di Obbe : 16-11-2010 alle 12:10. |
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Sep 2009
Messaggi: 375
|
Purtroppo non ho ancora visto gli array. Alla fine pensandoci ci sono arrivato da solo (senza array) anche se la mia soluzione non è per niente elegante, la posto comunque per aiutare qualcuno che potrebbe avere il mio stesso problema:
Codice:
#include <stdio.h>
main()
{
int c;
int z;
while((c=getchar()) != EOF)
{
if (z == ' ')
if (c == ' ')
continue;
putchar(c);
z=c;
}
}
Ringrazio comunque di cuore tutti quelli che si sono interessati e hanno provato a darmi una mano. E' probabile che mi rivedrete presto in questa sezione. Ciao ciao |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 08:09.




















