Jump to content

duvida sobre exercicio de strings


johnnymonteiro89
 Share

Recommended Posts

boas!

o seguinte exercicio está a dar-me segmentation fault e não consigo encontrar o erro 😕

"Especifique em C uma funcao que recebe tres argumentos, s, a, e b e dá como resultado a substring de s que começa na posição a e tem b caracteres. Caso não encontre, a função deverá retornar o apontador nulo que em C é representado pela constante NULL"

#include <stdio.h>
#include <string.h>

char *substrit(char s[], int a, int b)
{
   char *res;
   int i = a;
   if(b>=2 && b<=strlen(s)){
       while(i<=b || s[i]!='\0'){
           res[i] = s[i];
           i++;
       }
   }

   else
       return NULL;
}

int main(){
   char string[20];
   int p, c;
   printf("Introduz uma string: ");
   scanf("%s", string);
   printf("Introduz a posição onde começa a substring: ");
   scanf("%d", &p);
   printf("Introduz o nº de caracteres pretendido: ");
   scanf("%d", &c);
   printf("%s", substrit(string,p,c));
}
Link to comment
Share on other sites

Isto não tem muita lógica:

while(i<=b || s!='\0'){
            res = s;
            i++;
        }

segundo o que eu percebi vais querer retornar uma substring, mas nesse código não tás a retornar nada do genero de string.

1º tens que alocar memoria para a substring ser retornada.

2º tens que copiar os dados da string para a substring.

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

Quando é que apontas o res para um espaço de memória?

"[Os jovens da actual geração]não lêem porque não envolve um telecomando que dê para mirar e atirar, não falam porque a trapalhice é rainha e o calão é rei" autor: thoga31

Life is a genetically transmitted disease, induced by sex, with death rate of 100%.

Link to comment
Share on other sites

modifiquei o programa mas mesmo assim falta alguma coisa ainda que não encontrei

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

char *substrit(char s[], int a, int b)
{
   char *res;
   res = (char *)malloc(strlen(s)-a);
   int i;
   i = a;
   if(b>=2 && b<=strlen(s)-a){
       while(i<=b || s[i]!='\0'){
           res[i] = s[i];
           i++;
       }
      return res;
   }

   else
       return NULL;
}
Link to comment
Share on other sites

o erro ai, é que a variavel "i" irá ser maior do que 0.

res[i-a] = s[i];

com esta correcção deverá de funcionar direito.

EDIT: ainda tens que afinal um pouco mais o código para não copiar a string toda

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.