Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-05-2005, 19:07   #1
darkmax
Senior Member
 
L'Avatar di darkmax
 
Iscritto dal: Nov 2001
Città: Torino
Messaggi: 3092
[C] Programma cerca e cancella!!

Ho fatto un programma in c che chiede una stringa, poi la sottostringa da cercare in esso e poi un'altra sottostringa che sostituisce quella di prima..

Ora però devo fare un programma che.. presa una stringa ad esempio "camino" e poi una sottostringa, ad esempio "ami", me la cancelli.. dando come risultato "cno".. come si modifica il codice?

#include <stdio.h>
#define L1 10
#define L2 10
#define SORG 30
#define VECCHIA 10
#define NUOVA 10
#define DEST 30

typedef enum{FALSO,VERO} bool;

char* sottostringa(char* p, char* s);
bool SostPrimaOcc(char* vecchia, char* nuova, char* sorg, char* dest);

int main()
{
char* ris;
char vecchia[VECCHIA], nuova[NUOVA], sorg[SORG], dest[DEST];
char stringa[L1], pattern[L2];
bool ris1;

int scelta = -1;

while (scelta != 0)
{
printf("1) sottostringa\n2) SostPrimaOcc\n0) Esci\n\nScelta: ");
scanf("%d",&scelta);

switch(scelta)
{
case 1: printf("Inserisci la stringa in cui cercare (max 10 caratteri): ");
scanf("%s",stringa);

printf("Inserisci la sottostringa da cercare (max 10 caratteri): ");
scanf("%s",pattern);

ris = sottostringa(pattern, stringa);

if (ris == NULL)
{
printf("Non ho trovato %s in %s\n\n", pattern, stringa);
}
else
{
printf("Ho trovato %s in %s\n\n", pattern, stringa);
}
break;

case 2: printf("Inserisci la stringa in cui cercare (max 30 caratteri): ");
scanf("%s",sorg);

printf("Inserisci la sottostringa da cercare (max 10 caratteri): ");
scanf("%s",vecchia);

printf("Inserisci la sottostringa da sostituire (max 10 caratteri): ");
scanf("%s",nuova);

ris1 = SostPrimaOcc (vecchia, nuova, sorg, dest);

if (ris1 == FALSO)
{
printf("Non ho trovato %s in %s. La stringa e' rimasta: %s\n\n", vecchia, sorg, dest);
}
else
{
printf("Ho trovato %s in %s. La nuova stringa e': %s\n\n", vecchia, sorg, dest);
}
break;

case 0: break;
default : printf("Scelta non valida!\n\n");
break;
}
}

getch();
}

char* sottostringa (char* p, char* s)
{
char* i = p;
char* j = s;
int ris=0;
int cont=0;
char* found=NULL;

char* k = p;

while (*k != '\0')
{
cont++;
k++;
}

while (*j != '\0')
{
while (*i != '\0')
{
if (*i == *(j+ris))
{
ris++;
if (found == NULL)
found = j;
}
else
break;
i++;
}

if (ris == cont)
{
return found;
}
else
{
ris = 0;
found = NULL;
i = p;
}
j++;
}
return NULL;
}

bool SostPrimaOcc (char* vecchia, char* nuova, char* sorg, char* dest)
{
char* ris=sottostringa(vecchia,sorg);
int j;
char* i = sorg;

if (ris != NULL)
{
int cont=0;

char* k = vecchia;

while (*k != '\0')
{
cont++;
k++;
}

k = nuova;
int cont1=0;

while (*k != '\0')
{
cont1++;
k++;
}

k = dest;

while (i != ris)
{
*k = *i;
k++;
i++;
}

for (j = 0; j < cont1; j++)
{
*k = *nuova;
k++;
nuova++;
}

i += cont;

while (*i != '\0')
{
*k = *i;
k++;
i++;
}

*k='\0';

return VERO;
}
else
{
char* dest1 = dest;

while (*i != '\0')
{
*dest1 = *i;
i++;
dest1++;
}
*dest1='\0';
}

return FALSO;
}

Help vi prego..
darkmax è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2005, 19:09   #2
Fenomeno85
Senior Member
 
L'Avatar di Fenomeno85
 
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 non indenti io non mi metto a guardare il codice

~§~ 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
Fenomeno85 è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2005, 19:15   #3
darkmax
Senior Member
 
L'Avatar di darkmax
 
Iscritto dal: Nov 2001
Città: Torino
Messaggi: 3092
ho fatto copia e incolla dal dev c++.. ma come mai non lo indenta?
darkmax è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2005, 19:42   #4
darkmax
Senior Member
 
L'Avatar di darkmax
 
Iscritto dal: Nov 2001
Città: Torino
Messaggi: 3092
quando scrivo il messaggio me lo vede come indentato.. come mai qui no?
darkmax è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2005, 19:51   #5
Gica78R
Senior Member
 
L'Avatar di Gica78R
 
Iscritto dal: Mar 2005
Messaggi: 1653
Quote:
Originariamente inviato da darkmax
quando scrivo il messaggio me lo vede come indentato.. come mai qui no?
Prova a mettere il codice tra appositi tag 'CODE':

Codice:
int main()
{
 if (metti_i_tag)
    indenta=1;
 else
    indenta=0;
 return 0;
}
Per farlo basta cliccare sul cancelletto (#) che trovi nel menu nella finestra dell'editor del messaggio


Ciao
__________________
gica78r@ncc-1701:~$ tar -c
tar: Codardamente mi rifiuto di creare un archivio vuoto
Gica78R è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2005, 20:08   #6
darkmax
Senior Member
 
L'Avatar di darkmax
 
Iscritto dal: Nov 2001
Città: Torino
Messaggi: 3092
Codice:
#include <stdio.h>
#define L1  10
#define L2  10
#define SORG  30
#define VECCHIA  10
#define NUOVA  10
#define DEST  30

typedef enum{FALSO,VERO} bool;

char* sottostringa(char* p, char* s);
bool SostPrimaOcc(char* vecchia, char* nuova, char* sorg, char* dest);

int main()
{
    char* ris;
    char vecchia[VECCHIA], nuova[NUOVA], sorg[SORG], dest[DEST];
    char stringa[L1], pattern[L2];
    bool ris1;

    int scelta = -1;
    
    while (scelta != 0)
    {
        printf("1) sottostringa\n2) SostPrimaOcc\n0) Esci\n\nScelta: ");
        scanf("%d",&scelta);
        
        switch(scelta)
        {
            case 1: printf("Inserisci la stringa in cui cercare (max 10 caratteri): ");
                    scanf("%s",stringa);
            
                    printf("Inserisci la sottostringa da cercare (max 10 caratteri): ");
                    scanf("%s",pattern);

                    ris = sottostringa(pattern, stringa);
                    
                    if (ris == NULL)
                    {
                        printf("Non ho trovato %s in %s\n\n", pattern, stringa);
                    }
                    else
                    {
                        printf("Ho trovato %s in %s\n\n", pattern, stringa);
                    }
                    break;
                    
            case 2: printf("Inserisci la stringa in cui cercare (max 30 caratteri): ");
                    scanf("%s",sorg);
            
                    printf("Inserisci la sottostringa da cercare (max 10 caratteri): ");
                    scanf("%s",vecchia);
                    
                    printf("Inserisci la sottostringa da sostituire (max 10 caratteri): ");
                    scanf("%s",nuova);
            
                    ris1 = SostPrimaOcc (vecchia, nuova, sorg, dest);
                    
                    if (ris1 == FALSO)
                    {
                        printf("Non ho trovato %s in %s. La stringa e' rimasta: %s\n\n", vecchia, sorg, dest);
                    }
                    else
                    {
                        printf("Ho trovato %s in %s. La nuova stringa e': %s\n\n", vecchia, sorg, dest);
                    }
                    break;
                    
            case 0: break;
            default : printf("Scelta non valida!\n\n");
                      break;
        }
    }
    
    getch();
}

char* sottostringa (char* p, char* s)
{
    char* i = p;
    char* j = s;
    int ris=0;
    int cont=0;
    char* found=NULL;
    
    char* k = p;
    
    while (*k != '\0')
    {
    	cont++;
    	k++;
    }
    
    while (*j != '\0')
    {
    	while (*i != '\0')
    	{
        	if (*i == *(j+ris))
        	{
        		ris++;
        		if (found == NULL)
        			found = j;
        	}
        	else
        		break;
        	i++;
        }
        
        if (ris == cont)
        {
        	return found;
        }
        else
        {
        	ris = 0;
        	found = NULL;
        	i = p;
        }
        j++;
    }
	return NULL;
}

bool SostPrimaOcc (char* vecchia, char* nuova, char* sorg, char* dest)
{
	char* ris=sottostringa(vecchia,sorg);
	int j;
	char* i = sorg;
	
	if (ris != NULL)
	{
		int cont=0;
		
		char* k = vecchia;
		
		while (*k != '\0')
		{
			cont++;
			k++;
		}
		
		k = nuova;
		int cont1=0;
		
		while (*k != '\0')
		{
			cont1++;
			k++;
		}
		
		k = dest;
		
		while (i != ris)
		{
			*k = *i;
			k++;
			i++;
		}
		
		for (j = 0; j < cont1; j++)
		{
			*k = *nuova;
    		k++;
    		nuova++;
    	}
    	
    	i += cont;
    	
    	while (*i != '\0')
    	{
    		*k = *i;
    		k++;
    		i++;
    	}
    	
    	*k='\0';
    	
    	return VERO;
    }
    else
    {
    	char* dest1 = dest;
    	 
    	while (*i != '\0')
    	{
    		*dest1 = *i;
    		i++;
    		dest1++;
    	}
    	*dest1='\0';
    }
    
 	return FALSO;
}
darkmax è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2005, 01:00   #7
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
che casino ragazzo mio, che casino... bastavano 35 righe di codice:
Codice:
#include <stdlib.h>
#include <stdio.h>
#include <string.h>

int main() {
	char s1[0x400], s2[0x400];
	int l1, l2;
	char done = 0;
	int i, max;
	printf("stringa principale: ");
	gets(s1);
	printf("sottostringa da eliminare: ");
	gets(s2);
	l1 = strlen(s1);
	l2 = strlen(s2);
	max = l1 - l2 + 1;
	for (i = 0; i < max; i++) {
		if (!strncmp(s1 + i, s2, l2)) {
			int j;
			for (j = i; j < max; j++) {
				s1[j] = s1[j + l2];
			}
			done = 1;
			break;
		}
	}
	if (done) {
		printf("stringa risultante: %s\n", s1);
	}
	else {
		printf("sottostringa non trovata\n");
	}
	system("pause");
	return 0;
}
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2005, 01:14   #8
darkmax
Senior Member
 
L'Avatar di darkmax
 
Iscritto dal: Nov 2001
Città: Torino
Messaggi: 3092
dammi una mano allora..
darkmax è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2005, 01:43   #9
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
il programma è quello, sta là ed è scritto in C standard
quel programma prende in input due stringhe, cerca la seconda nella prima e se la trova la rimuove, è quello che volevi
sono solo 35 righe di codice, quindi non ci vuole molto a leggerle e capirle
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2005, 10:30   #10
darkmax
Senior Member
 
L'Avatar di darkmax
 
Iscritto dal: Nov 2001
Città: Torino
Messaggi: 3092
Il bello è che devo farlo con i puntatori..
darkmax è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Xbox Cloud Gaming arriva su Amazon Fire ...
Un blackout a San Francisco manda in til...
Windows 11 è diventato più...
Apple cambia strategia a causa della cri...
007 First Light: uscita rimandata di due...
Samsung Galaxy A37 e A57: il comparto fo...
DAZN lancia la sua offerta di Natale: My...
Gigabyte fa marcia indietro? Sparito il ...
Alcuni rivenditori giapponesi bloccano l...
Le feste non placano Amazon, anzi: aggio...
Roborock Q10 S5+ a un super prezzo: robo...
Formula sceglie WINDTRE BUSINESS per gar...
EXPO 1.20: AMD migliora il supporto all'...
MacBook Pro con chip M4, 24GB di RAM e 1...
Lefant M330 da 6.000Pa a 139€ o ECOVACS ...
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: 20:58.


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