Форум программистов, компьютерный форум CyberForum.ru

Упорядочить строку по убыванию длин слов - C++

Восстановить пароль Регистрация
 
мышьяк
 Аватар для мышьяк
0 / 0 / 0
Регистрация: 09.09.2010
Сообщений: 3
27.12.2010, 20:43     Упорядочить строку по убыванию длин слов #1
Нам дан некий файл состоящий из слов, разделителями между которыми является некоторое множество знаков препинания.
Нужно упорядочить слова в строках по убыванию длин слов, результат сортировки записать в файл.

Я тут набросал код, однако при выводе он выдает какой-то бред, слабо напоминающий исходник 0_о Объясните, в чем ошибка, пожалуйста!


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <iostream>
#include <cstring>
#include <fstream>
#include <stdlib.h>
 
using namespace std;
using std::ifstream;
using std::ofstream;
 
void SortMas (char*p,char*q) // сортировка массива строк по убыванию длин слов
{
    int a,b;
    char*k;
    k=new char[150];
       a=strlen(p);
      b=strlen(q);
 
         if(a<b)
     {
         strcpy(p,k);
         strcpy(q,k);
         strcpy(p,q);
     }
     return;
}
 
int main ()
{
  ifstream InFile;
  ofstream OutSort;
  InFile.open("Input.txt");
  OutSort.open("Out_sort.txt");
 
char div[] = "(){}[]<>;\"=+-*., ";
char*text,*s1,*s2;
text=new char[30];
s1=new char[30];
s2=new char[30];
 
    while (!InFile.eof())
  {
       InFile.getline(text,150);
       strcpy(p,text);
       s1=strtok(p,div);
       s2=strtok(NULL,div);
 
         SortMas(s1,s2);
         OutSort<<s1<<" "<<s2<<endl;
         s1=strcpy(s1,s2);
         s2=strtok(NULL,div);
 }
 
OutSort.close();
InFile.close();
 
}
Добавлено через 22 часа 58 минут
как выяснилось, задача решается вот так (а вдруг кому пригодится):

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
void SortMas (int *m, char **r, int l) // сортировка массива строк по убыванию длин слов
{
    int t;
    char *k;
    k=new char[30];
    for (int i=0;i<l-1;i++)
{
        for (int j=i+1;j<l; j++)
    {
            if(m[i]<m[j])
        {
         t=m[i];
         m[i]=m[j];
         m[j]=t;
          strcpy(k,r[i]);
          strcpy(r[i],r[j]);
          strcpy(r[j],k);
      }
    }
 }
 
     return;
}
 
int main ()
{
 while (!InFile.eof())
  {
      i=0;
   InFile.getline(text,150);
   strcpy(p,text);
   s1=strtok(p,div);
     while (s1!=NULL)
     {
      mas[i]=new char[30]; // слова
      strcpy(mas[i],s1);
      mac[i]=strlen(s1);
      i++;
      s1=new char[30];
      s1=strtok(NULL,div);
     }
   SortMas(mac,mas,i);
   for (int k=0; k<i; k++)
    OutSort<<mas[k]<<" ";
   OutSort<<endl;
 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.12.2010, 20:43     Упорядочить строку по убыванию длин слов
Посмотрите здесь:

Сформировать гистограмму длин слов, хранящихся в текстовом файле C++
C++ Вывести вертикальную гистограмму длин слов введенного текста
Вывести вертикальную гистограмму длин слов введенного текста C++
C++ частоту распределения длин слов
C++ Функция, получает строку слов и рзделителей, а на выходе имеет массив слов из строки и количество этих слов
C++ Матрица (упорядочить каждую строку по убыванию элементов)
Напишите программу, печатающую гистограммы длин вводимых слов C++
Упорядочить строку с наименьшим количеством нечетных чисел по убыванию C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 15:05. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru