Função para remover Substring
Publicado por Thiago 25/06/2007
[ Hits: 12.179 ]
Considerem esta função em fase de teste.
Eu a considero em fase de teste, pois às vezes o programador
acha que testou todas as possibilidades de erro e vem um
péba e descobre um bug!
Se alguém (péba - brincadeirinha =) ) descobrir algum erro
ou tiver alguma sugestão para melhorar, me mande um e-mail.
:)
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
char *remove_substr (char *string, char *substring);
int main (int argc, char *argv[])
{
char string[50];
char substring[50];
printf ("\nInforme uma string: ");
fflush (stdin);
fgets (string, 50, stdin);
/* scanf nao foi usado pois encerra ao encontrar um espaco o enter "\n".
Vou utilizar strings grandes. */
printf ("\nInforme uma substring: ");
fflush (stdin);
gets (substring);
/* Estou usando o gets pois ele nao coloca o caracter terminador de string
'{FONTE}' o que tornaria nossa substring diferente.
Por exemplo: string: thiago{FONTE}
substring: thi{FONTE}
A substring existente e thi.
Quero lembrar que o uso do gets nao e recomendado pois este nao verifica o tamanho da
string lida o que pode causar estouro de buffer.
Os caracteres excedentes podem sobrescrever certas areas da memoria ou tentar
(isso depende do Sistema Operacional em questao).
Quando pensar em uma forma de tirar o '{FONTE}' ai eu mudo o codigo. :) */
printf ("\nString alterada = %s\n", remove_substr (string, substring) );
return 0;
}
// Minha funcao para remover substring.
char *remove_substr (char *str, char *substr)
{
char *aux; // guarda o endereco da pos inicial de substr na str.
int tam;
register int i; // armazenado em registrador.
tam = strlen (substr); // armazena tamanho da substr.
aux = strstr (str, substr); // retorna endereco inicial da substr.
if (aux) // A substring esta contida na string? (endereco retornado?)
{
if (aux == str) // remove substring no inicio.
for (i = 0; i < tam; i++, ++str);
else
{
/* i guarda a posicao inicial da substring
tam e o tamanho do deslocamento (quantidade de caracteres apos
a substring). */
for (i = (aux - str); i < strlen(str); i++)
str[i] = str[i + tam];
}
return str;
}
else
return " ";
}
Exemplo de janela utilizando o compilador Vala
Algoritmo em C - Ordenação por Inserção
programa que mostra o uso de registros em C. Cadastra 10 funcionarios
Nenhum comentário foi encontrado.
File Browser: Crie sua Nuvem Pessoal Privada
A produção de áudio e vídeo no Linux e as distribuições dedicadas a esse fim
Criptografando sua Home com Gocryptfs para tristeza do meliante
A Involução do Linux e as Lambanças Desnecessárias desde o seu Lançamento
O Journal no Linux para a guarda e consulta de logs do sistema
Otimizando o uso de Memória RAM no Ubuntu com zRAM
Usando alias no Terminal para comandos longos
Simplificando o manual do terminal no Ubuntu 26.04
Bloqueio da instalação e reinstalação do Snap (snapd) no Ubuntu
Continuando meus tópicos anteriores (11)
GLPI Cards de filtros de pesquisa (2)









