Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-08-2008, 10:24   #1
yoghi87
Member
 
L'Avatar di yoghi87
 
Iscritto dal: Feb 2008
Messaggi: 84
[C] stringa inversa

Salve dovrei scrivere un funzione che inverte una stringa, avevo pensato a qualcosa del genere:
Codice:
void reverse(char in[], char out[])
{
  int i, c;

  in[i] = 0;

	for(i = 0; i < c; ++i){
	    in[i] = c;
	    --i;	}

	if( c == '\n'){
	   out[i] = in[i];
			}

}
Potete gentilmente dirmi se può andar bene o se ci sono errori darmi dei consigli? GRAZIE
yoghi87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 10:44   #2
magix2003
Senior Member
 
L'Avatar di magix2003
 
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
No. Ci sono degli errori. Il primo, il più lampante, è che la variabile c non è inizializzata.
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole"

magix2003 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 10:50   #3
Noixe
Member
 
Iscritto dal: Aug 2008
Messaggi: 51
Quote:
Originariamente inviato da yoghi87 Guarda i messaggi
Codice:
	
for(i = 0; i < c; ++i){
	    in[i] = c;
	    --i;	}
ma incrementi e decrementi la variabile i nello stesso ciclo?

L'hai testato quel codice?
Noixe è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 11:08   #4
yoghi87
Member
 
L'Avatar di yoghi87
 
Iscritto dal: Feb 2008
Messaggi: 84
no non lo testata la funzione, pensavo di incrementare la i e poi decrementarla per copiare l'inverso.....
yoghi87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 11:26   #5
the_ivos
Member
 
L'Avatar di the_ivos
 
Iscritto dal: Aug 2008
Città: Bergamo
Messaggi: 116
Alla funzione devi passare anche la lunghezza della stringa...

poi io farei cosi (non lo testato):

Codice:
void reverse(char stringa[], int lunghezza)
{
  int i, cicli;
  char carattere;

  i = 0;
  cicli = lunghezza / 2;

  for(; cicli > 0;cicli--)
  {
	carattere = stringa[i];
	stringa[i] = stringa[lunghezza];
	stringa[lunghezza]= carattere;
	i++;
 	lunghezza--;
  }
}
__________________
Non andare piu veloce di quanto il tuo angelo custode possa volare
the_ivos è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 11:27   #6
magix2003
Senior Member
 
L'Avatar di magix2003
 
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
A me sembra più semplice così:

Codice:
char aString[] = "ciao";
    int length = strlen(aString);
    char bString[length + 1];
    int j =0;
    int i;
    bString[length] = '\0';
    for (i = (length - 1); i >=0; i--) {
        bString[j] = aString[i];
        j++;
    }
    printf("%s\n", bString);
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole"

magix2003 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 11:28   #7
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Puoi fare una reverse in place (la butto giù al momento, potrebbe essere sbagliata):
Codice:
void reverse(char *str)
{
  size_t len = (strlen(str) - 1);
  unsigned x;
  char *end;

  for (end = &str[len]; len > 1; ++str, --end)
  {
    char tmp = *end;

    *end = *str;
    *str = tmp;
    len -= 2;
  }
}
Ovviamente presupponendo che str sia null-terminated.

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 25-08-2008, 11:30   #8
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Azz non avevo notato altre due soluzioni prima di me... sto invecchiando.
__________________

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 25-08-2008, 11:38   #9
slartibartfast
Senior Member
 
L'Avatar di slartibartfast
 
Iscritto dal: May 2005
Messaggi: 564
La soluzione più semplice potrebbe essere una cosa così:
Codice:
#include <stdio.h>
#include <string.h>

void reverse(char *in, char *out)
{
	out += strlen (in) - 1;
	*out = 0;
	
	while (*in)
		*out-- = *in++;
}

int main(int argc, char *argv[])
{
	char buf[5];
	reverse ("ciao", buf);
	puts (buf);
	return 0;
}
slartibartfast è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 11:59   #10
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da slartibartfast Guarda i messaggi
La soluzione più semplice potrebbe essere una cosa così:
[code]#include <stdio.h>
#include <string.h>

void reverse(char *in, char *out)
{
out += strlen (in) - 1;
*out = 0;

while (*in)
*out-- = *in++;
}
Così non sovrascrivi il terminatore appena impostato?
__________________

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 25-08-2008, 12:17   #11
slartibartfast
Senior Member
 
L'Avatar di slartibartfast
 
Iscritto dal: May 2005
Messaggi: 564
Quote:
Originariamente inviato da DanieleC88 Guarda i messaggi
Così non sovrascrivi il terminatore appena impostato?
Giusto, mio errore

così dovrebbe andare bene
Codice:
void reverse(char *in, char *out)
{
	out += strlen (in);
	*out-- = 0;
	
	while (*in)
		*out-- = *in++;
}
slartibartfast è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 12:47   #12
yoghi87
Member
 
L'Avatar di yoghi87
 
Iscritto dal: Feb 2008
Messaggi: 84
Grazie a tutti, esaminerò i codici da voi scritti.
yoghi87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 12:52   #13
yoghi87
Member
 
L'Avatar di yoghi87
 
Iscritto dal: Feb 2008
Messaggi: 84
comunque la volevo scrivere senza usare la funzione strlen.... è possibile?
yoghi87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 13:15   #14
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Sì, puoi o passare alla funzione la lunghezza della stringa come ti ha consigliato the_ivos, oppure devi andare in fondo alla stringa di input e poi tornare indietro. Ma perché non vuoi usare strlen?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 13:47   #15
yoghi87
Member
 
L'Avatar di yoghi87
 
Iscritto dal: Feb 2008
Messaggi: 84
stò seguendo degli esercizi e ancora non è previsto l'uso di tali funzioni...
yoghi87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 14:25   #16
Albi89
Senior Member
 
Iscritto dal: May 2004
Città: Napoli
Messaggi: 773
Quote:
Originariamente inviato da yoghi87 Guarda i messaggi
stò seguendo degli esercizi e ancora non è previsto l'uso di tali funzioni...
Puoi farti da solo la tua strlen allora, in fondo dovrà solo controllare un carattere alla volta finchè non trova il valore '\0'
__________________
If builders built buildings the way programmers wrote programs, then the first woodpecker that came along would destroy civilization.
--Gerald Weinberg
Albi89 è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 16:32   #17
slartibartfast
Senior Member
 
L'Avatar di slartibartfast
 
Iscritto dal: May 2005
Messaggi: 564
Quote:
Originariamente inviato da Albi89 Guarda i messaggi
Puoi farti da solo la tua strlen allora, in fondo dovrà solo controllare un carattere alla volta finchè non trova il valore '\0'
Esatto, così può andare?
Codice:
void reverse(char *in, char *out)
{
	char *c = in;
	
	while (*c++);
	out += (c - in - 1);
	*out-- = 0;
	
	while (*in)
		*out-- = *in++;
}
slartibartfast è offline   Rispondi citando il messaggio o parte di esso
Old 25-08-2008, 19:52   #18
yoghi87
Member
 
L'Avatar di yoghi87
 
Iscritto dal: Feb 2008
Messaggi: 84
OK grazie a tutti per i consigli....
yoghi87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-03-2009, 15:45   #19
DaRk\S0ul
Member
 
Iscritto dal: Nov 2003
Messaggi: 142
salve io avrei fatto in questo modo, premetto che dal libro su cui sto studiando, sono alle prime armi, dispongo di una funzione che mi crea la stringa dai caratteri in entrata e mi ritorna la sua lunghezza, dati che conto di utilizzare nella mia funzione reverse. la funzione è
Codice:
char reverse (char stringa[], lunghezza)
{	int lunghezza;
	char stringarev[lunghezza];
	char stringa[lunghezza];
	int i;
	for (i=lunghezza; i<= lunghezza  && stringa[i]!='\0' && stringa[i]!='\n';--i )
		{
			int j=0;
			stringarev[j]=stringa[i];
				++j;
			}
			
		if (stringa[i]=='\0')
			--i;
		else	
			if (stringa[i]=='\n')
				--i;
			
	return stringarev;
	
	}
non ho avuto modo di provarla anche perchè ho difficoltà con il main che mi da 10000 errori.

help!
DaRk\S0ul è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
L'IA ha fatto incetta anche di processor...
Affidabilità delle GPU NVIDIA cro...
Maxi incendio in un parcheggio BYD: fiam...
Apple potrebbe diventare il terzo produt...
L'IA aiuta i computer quantistici con i ...
Nutanix Database Platform è ora i...
iliad lancia il 5G Standalone in Italia:...
Alexa+ da oggi disponibile anche in Ital...
SpaceX Starship: Ship 39 ha eseguito il ...
Auto usate: Peugeot 3008 tra le peggiori...
YMTC, il produttore di memorie 100% cine...
I gamer rinunciano alla RAM ma non agli ...
Oltre 100 estensioni Chrome malevole rub...
Multi Frame Generation 5x e 6x anche su ...
Kraken sotto ricatto dopo due accessi in...
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: 19:01.


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