Jump to content

Recommended Posts

Posted

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));
}
Posted

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."

Posted

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%.

Posted

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;
}
Posted

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."

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
×
×
  • 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.