johnnymonteiro89 Posted March 28, 2012 at 01:00 PM Report #446120 Posted March 28, 2012 at 01:00 PM 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)); }
pikax Posted March 28, 2012 at 01:14 PM Report #446122 Posted March 28, 2012 at 01:14 PM 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."
brunoais Posted March 28, 2012 at 01:15 PM Report #446123 Posted March 28, 2012 at 01:15 PM 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%.
johnnymonteiro89 Posted March 28, 2012 at 01:39 PM Author Report #446128 Posted March 28, 2012 at 01:39 PM 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; }
pikax Posted March 28, 2012 at 01:45 PM Report #446132 Posted March 28, 2012 at 01:45 PM 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."
johnnymonteiro89 Posted March 28, 2012 at 01:53 PM Author Report #446136 Posted March 28, 2012 at 01:53 PM muito obrigado! era mesmo isso que estava mal 👍
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