0
I’m doing a program that sorts the words, only if they’re the same size you can’t change places, I’m stuck in that part, the code I already have
#include <stdio.h>
#include <string.h>
void coloca(char nomes[][100], char *frase, int *tam);
void ordena(char nomes[][100], int tam);
int main(int argc, char** argv)
{
char nomes[100][100], frase[2501];
int tam, i, teste;
scanf("%d", &teste);
getchar();
while(teste--)
{
tam = 0;
scanf("%[^\n]", frase);
coloca(nomes, frase, &tam);
ordena(nomes, tam);
printf("%s", nomes[0]);
for(i = 1; i < tam; i++)
{
printf(" %s", nomes[i]);
}
printf("\n");
getchar();
}
return 0;
}
void coloca(char nomes[][100], char *frase, int *tam)
{
char *ptr = strtok(frase, " ");
while(ptr != NULL)
{
strcpy(nomes[(*tam)++], ptr);
ptr = strtok(NULL, " ");
}
}
void ordena(char nomes[][100], int tam)
{
int i, j;
char aux[100];
for(i = 0; i < tam; i++)
{
for(j = i + 1; j < tam; j++)
{
if(strlen(nomes[i]) == strlen(nomes[j]))
{
}
else if(strlen(nomes[i]) < strlen(nomes[j]))
{
strcpy(aux, nomes[i]);
strcpy(nomes[i], nomes[j]);
strcpy(nomes[j], aux);
}
}
}
}
Example entree Top Coder comp Wedn at Midnight
Exit
Midnight Coder comp Wedn Top at
Can you give more examples ? So if all strings have the same size nothing is changed ?
– Isac