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

реверсивный переворот - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 5.00
ULTRAS
0 / 0 / 0
Регистрация: 03.03.2012
Сообщений: 8
03.03.2012, 22:15     реверсивный переворот #1
Создать 2 объекта разработанного класса. Одной из компонент класса является динамическая символьная строка. В результате выполнения программы в обоих объектах выполнить реверсивный переворот каждого слова строки. Содержимое объектов (их строки) до и после обмена вывести на экран.
как этот переворот сделать,у меня индексы строковые не сходятся
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.03.2012, 22:15     реверсивный переворот
Посмотрите здесь:

C++ Переворот строки
Переворот строки C++
Переворот строки C++
Переворот масива C++
Переворот слов C++
Переворот массива C++
C++ Переворот массива
Переворот слов C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Konstantin_D
 Аватар для Konstantin_D
14 / 14 / 2
Регистрация: 21.07.2011
Сообщений: 89
04.03.2012, 02:06     реверсивный переворот #2
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
#include <iostream>
#include <cstring>
using namespace std;
 
class Word
{
private:
    char* pch;
    // Конструктор копирования и оператор присваивания 
    // не реализуем и не используем
    Word(const Word& w): pch(0) {}
    Word& operator=(const Word& w) {return *this;}
public:
    Word(char* p);
    ~Word() {delete [] pch;}
    void reverse();
    friend ostream& operator<<(ostream& os, const Word& w);
};
Word::Word(char* p)
{
    pch = new char[strlen(p)+1];
    strcpy(pch, p);
}
void Word::reverse()
{
    int len = strlen(pch);
    char* tmp = new char[len+1];
    int j = 0;
    for (int i = len-1; 0 <= i; --i)
        tmp[j++] = pch[i];
    tmp[len] = '\0';
    delete [] pch;
    pch = tmp;
}
ostream& operator<<(ostream& os, const Word& w)
{
    os << w.pch;
    return os;
}
 
int main()
{
    Word a("abcdef");
    Word b("klmnop");
    cout << a << " " << b << endl;
    a.reverse(); 
    b.reverse();
    cout << a << " " << b << endl;
}
Добавлено через 32 минуты
Это был переворот всей строки, если переворот каждого слова строки, то:
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 <cstring>
#include <string>
#include <sstream>
using namespace std;
 
class Word
{
private:
    char* pch;
    // Конструктор копирования и оператор присваивания 
    // не реализуем и не используем
    Word(const Word& w): pch(0) {}
    Word& operator=(const Word& w) {return *this;}
public:
    Word(char* p);
    ~Word() {delete [] pch;}
    void reverse();
    friend ostream& operator<<(ostream& os, const Word& w);
};
Word::Word(char* p)
{
    pch = new char[strlen(p)+1];
    strcpy(pch, p);
}
void Word::reverse()
{
    istringstream iss(pch);
    string word, temp;
    while ( iss >> word )
    {
        temp += string(word.rbegin(), word.rend());
        temp.push_back(' ');
    }
    int lenNewStr = temp.size() - 1; // последний - пробел - не нужен
    char* p = new char[lenNewStr + 1];
    for (int i=0; i < lenNewStr; ++i)
        p[i] = temp[i];
    p[lenNewStr] = '\0';
    delete [] pch;
    pch = p;
}
ostream& operator<<(ostream& os, const Word& w)
{
    os << w.pch;
    return os;
}
 
int main()
{
    Word a("abcdef klmnop rstuf");
    Word b("klmnop 12345 6789");
    cout << a << endl << b << endl;
    a.reverse(); 
    b.reverse();
    cout << "* reverse *\n" << a << endl << b << endl;
}
Yandex
Объявления
04.03.2012, 02:06     реверсивный переворот
Ответ Создать тему
Опции темы

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