johnnymonteiro89 Posted March 28, 2012 Report Share Posted March 28, 2012 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 More sharing options...
pikax Posted March 28, 2012 Report Share Posted March 28, 2012 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 More sharing options...
brunoais Posted March 28, 2012 Report Share Posted March 28, 2012 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 More sharing options...
johnnymonteiro89 Posted March 28, 2012 Author Report Share Posted March 28, 2012 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 More sharing options...
pikax Posted March 28, 2012 Report Share Posted March 28, 2012 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 More sharing options...
johnnymonteiro89 Posted March 28, 2012 Author Report Share Posted March 28, 2012 muito obrigado! era mesmo isso que estava mal 👍 Link to comment Share on other sites More sharing options...
Recommended Posts
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 accountSign in
Already have an account? Sign in here.
Sign In Now