
Enviado em 04/04/2016 - 21:41h
Olá, tenho um exercico em que recebeo N strings e devo retornar as strings ordenadas com as maiores palavras na frente.#include <stdio.h>
#include<string.h>
#define MAX 50
/* Uma struct para armazenar as strings de entrada.
** Outra struct para armazenar as palavras que serão quebradas na função quebra_palavra.
*/
struct Palavras {
char palavra[MAX];
};
struct Palavras partes[MAX];
int quebra_frase (char frase[MAX]);
int main (void) {
struct Strings {
char frase [MAX];
};
int n, i=0, num_palavra;
scanf("%d", &n);
struct Strings string[n];
while (i<n+1) {
fgets(string[i].frase, MAX, stdin);
i++;
}
num_palavra = quebra_frase(string[1].frase);
i=0;
while (i<num_palavra) {
printf("%s\n", partes[i].palavra);
i++;
}
return 0;
}
int quebra_frase (char frase[MAX]) {
int p=0, i=0, count=0, n=0;
for (i=0;i<strlen(frase);i++) {
if (frase[i] == ' ' || frase[i] == '\n') {
while (p<i) {
partes[count].palavra[n] = frase[p];
n++;
p++;
}
count++;
p=i+1;
n=0;
}
}
return count;
}
/*count é o numero de partes,
**n percorre a string da palavra
**p percorre as posições da palavra a ser guardada */
IA Turbina o Desktop Linux enquanto distros renovam forças
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
Atualizando o Fedora 42 para 43
Como saber se o seu e-mail já teve a senha vazada?
Como descobrir se a sua senha já foi vazada na internet?
E aí? O Warsaw já está funcionando no Debian 13? [RESOLVIDO] (15)
Secure boot, artigo interessante, nada técnico. (4)
copiar library para diretorio /usr/share/..... su com Falha na a... (1)









