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

Списки С++ - C++

Восстановить пароль Регистрация
 
A555
51 / 51 / 2
Регистрация: 04.04.2011
Сообщений: 209
08.04.2011, 20:22     Списки С++ #1
все привет
вот само задание
Создать список слов. Рассортировать список (слова) по их длине. Слова с одинаковой длиной сортировать по двум первым буквам.
я сделал всё только что то не могу сообразить как сделать сортировку при равной длине слов по двум первым буквам
вот мой код
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
57
#include <iostream>
#include <stdlib>
#include <stdio>
#include <conio>
#include <math>
#define FOR for(int i=0;i<x;i++)
struct RP
{char *slovo;};
class RPR
{RP *ob;
 int x;
 double q;
  public:
RPR(int n=5)
{x=n;
   ob=new RP[x];
   FOR
    ob[i].slovo=new char[80];
   }
void vvod()
{
FOR
  scanf("%s",ob[i].slovo);
   }
void sort()
 {
  char*q;
  int i,j;
for(j=1;j<x;j++)
        {
            for(i=0;i<x-j;i++)
            { if(strlen(ob[i].slovo)<strlen(ob[i+1].slovo))
                {
                q=ob[i].slovo;
                ob[i].slovo=ob[i+1].slovo;
                ob[i+1].slovo=q;
            }
            //if(strlen(ob[i].slovo)==strlen(ob[i+1].slovo))
            }
         }
      }
 void vivod()
 { FOR
   printf("\n%s",ob[i].slovo);
 
 }
};
 void main()
{
int n;
scanf("%d",&n);
RPR ob(n);
ob.vvod();
ob.sort();
ob.vivod();
getch();
}
если у кто нить может помочь подскажите или напиши по возможности как это сделать заранее спс )

Добавлено через 19 минут
всё простите что беспокоил нашёл способ) если кому нужен код вот держите
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
57
58
59
60
61
62
63
64
65
#include <iostream>
#include <stdlib>
#include <stdio>
#include <conio>
#include <math>
#define FOR for(int i=0;i<x;i++)
struct RP
{char *slovo;};
class RPR
{RP *ob;
 int x;
 double q;
  public:
RPR(int n=5)
{x=n;
   ob=new RP[x];
   FOR
    ob[i].slovo=new char[80];
   }
void vvod()
{
FOR
  scanf("%s",ob[i].slovo);
   }
void sort()
 {
  char*q;
  int i,j;
for(j=1;j<x;j++)
        {
            for(i=0;i<x-j;i++)
            { if(strlen(ob[i].slovo)<strlen(ob[i+1].slovo))
                {
                q=ob[i].slovo;
                ob[i].slovo=ob[i+1].slovo;
                ob[i+1].slovo=q;
            }
            if(strlen(ob[i].slovo)==strlen(ob[i+1].slovo))
                {
                if((ob[i].slovo[0]+ob[i].slovo[1])>(ob[i+1].slovo[0]+ob[i+1].slovo[1]))
                {
                  q=ob[i].slovo;
                        ob[i].slovo=ob[i+1].slovo;
                        ob[i+1].slovo=q;
                }
                }
            }
         }
      }
 void vivod()
 { FOR
   printf("\n%s",ob[i].slovo);
 
 }
};
 void main()
{
int n;
scanf("%d",&n);
RPR ob(n);
ob.vvod();
ob.sort();
ob.vivod();
getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.04.2011, 20:22     Списки С++
Посмотрите здесь:

C++ C++ списки
C++ Списки в С++
C++ списки
С++ списки C++
C++ Списки
Списки в c++ C++
Списки, как склеить списки между собой? C++

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

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

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