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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ while (истинное условие). не работает! http://www.cyberforum.ru/cpp-beginners/thread220950.html
вот пишу код к очередному примеру из книги #include <iostream> using namespace std; int main(){ int x, y, z; while ( x != -1 || y != -1){ cout << "vvedite chislo rabotnikov" << endl; cin >> x;
C++ для вводы и вывода использовать printf/scanf помогите пожалуйста. ввести с клавиатуры кол-во студентов в группе,фамилии и их средние баллы(с точностью до 2 знаков). считать фамилии в массив а и средние баллы в массив b. далее вывести на экран фамилии и средние баллы студентов которых средний балл меньше чем 5.0 причем средний балл с точностью до 1 знака. подсчитать средний балл группы и вывести на экран для вводы и вывода... http://www.cyberforum.ru/cpp-beginners/thread220944.html
C++ Записать строку заменив каждую из последовательностей ее значением в десятичной системе счисления
Пожалуйста помогите написать задачу!!!!!!!!!!!!!Плизззззззззз!!!!! Дана строка содержащая текст и последовательности из 0 и 1 (двоичные числа). Записать строку заменив каждую из последовательностей ее значением в десятичной системе счисления.
ВС Экспресс 2008 не опазнает cout, cin. C++
Здравствуйте. Вроде все нормально делал. Файл *.сpp подключил #include <iostream> почему так?
C++ Квадратная матрица http://www.cyberforum.ru/cpp-beginners/thread220927.html
Помогите братаны.. Дана целочисленная квадратная матрица. Определить: 1) произведение элементов в тех строках, которые не содержать отрицательных элементов; 2) максимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы.
C++ Дано целое число N(>0).используя операции деления нацело и взятия остатка от деления, найти количество и сумму его цифр Дано целое число N(>0).используя операции деления нацело и взятия остатка от деления, найти количество и сумму его цифр. :wall::( подробнее

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

Я тут набросал код, однако при выводе он выдает какой-то бред, слабо напоминающий исходник 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;
 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru