Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 09.09.2010
Сообщений: 3
1

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

27.12.2010, 20:43. Показов 1536. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Нам дан некий файл состоящий из слов, разделителями между которыми является некоторое множество знаков препинания.
Нужно упорядочить слова в строках по убыванию длин слов, результат сортировки записать в файл.

Я тут набросал код, однако при выводе он выдает какой-то бред, слабо напоминающий исходник 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;
 
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.12.2010, 20:43
Ответы с готовыми решениями:

Упорядочить слова в предложении по возрастанию длин слов
Добрый вечер. Есть код на С++, необходимо реализовать дополнительное задание - пусть строка...

Определить находятся ли слова в порядке возрастания длин слов. Если нет то упорядочить их
с++ строки

Строка: Упорядочить строку по убыванию длин слов
Обработка символов и строк на языке паскаль Задача Упорядочить строку по...

Строки. Упорядочить по убыванию длин слов строку, в которой минимальное слово
Нуждаюсь в вашей помощи!!!!Очень прошу помочь...Нужно написать программу по условиям:Дан текст....

0
27.12.2010, 20:43
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
27.12.2010, 20:43
Помогаю со студенческими работами здесь

Определить, находятся ли слова строки в порядке возрастания длин слов. Если нет, то упорядочить их
Определить, находятся ли слова строки в порядке возрастания длин слов. Если нет, то упорядочить их.

Сформировать строку, состоящую из чисел длин слов в исходной строке
Помогите, пожалуйста. Как будет выглядеть код программы на форме в c#: Дана строка...

Ввести строку. Вывести пословно в порядке убывания длин слов
Ввести строку. Вывести пословно в порядке убывания длин слов.

Сформировать новую строку, состоящую из чисел длин слов в исходной строке
задача такая: Дана строка символов, состоящая из произвольного текста на английском языке, слова...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru