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

Помогите исправить ошибку - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ задача на С++ http://www.cyberforum.ru/cpp-beginners/thread371192.html
найти все углы треугольника по известным сторонам.предусмоттерть перевод радианной меры угла в градусы,минуты и секунды
C++ Выравнивание структур Подскажите пожалуйста, как в Си++ задать структуру/класс/тип данных, чтобы она/её поля были выровнены на одределённую границу в памяти, например 8 байт? И как сделать, чтобы функция malloc/new тоже выдавала результат с выравниванием? http://www.cyberforum.ru/cpp-beginners/thread371188.html
Если все элементы «двусвязного списка» отрицательны, то удалить элемент «стека» C++
помогите,пожалуйста... -Если все элементы «двусвязного списка» отрицательны, то удалить элемент «стека». Результат проверить.
vs--2010 C++
1. Программа для книжного магазина. Компьютер запрашивает стоимость книг, сумму денег, внесенную покупателем. Если сдачи не требуется, выводит сообщение «Спасибо»; если денег внесено больше, чем необходимо, то выводит «Возьмите сдачу» и указывает сумму сдачи; если денег недостаточно, то печатает сообщение об этом и указывает размер недостающей сдачи. 2. Программа запрашивает целое число от 2 до...
C++ Шумящие биты в WAV http://www.cyberforum.ru/cpp-beginners/thread371150.html
Вот такой вопросик как писать программу для сохранения собственного сообщение в звуковом файле расширения .WAV программа должна спрашивать сообщение далее его записывать в фаил формата WAV (подсовываем программе трек с песенкой допустим) программа считывает из WAV файла сообщение и выводит его на экран как вообще такое реализовать?? о.О пробовал такое сделать с картинкой BMP -...
C++ Одномерный массив. Дан одномерный массив состоящий из n вещественных элементов. Сжать массив удалив из него все элементы, модуль которых не превышает единицу.Освободившиеся в конце массива элементы заполнить нулями. подробнее

Показать сообщение отдельно
Sheishin
Сообщений: n/a
23.10.2011, 17:26     Помогите исправить ошибку
Условие задачи
Из входного потока вводится произвольное число строк. Каждая строка представляет собой
последовательность слов , разделенных одним или несколькими пробелами и/или знаками табуляции.
Длина каждой строки не превышает 80 символов . Конец ввода определяется концом файла
Для каждой строки сформировать строку , поместив в нее слова исходной строки ,
буквы в которой записаны в обратном порядке . В полученной строке слова разделять только одним пробелом .Полученную строку вывести на экран
Каждая строка представлена массивом символов , доступ к элементам массива осуществляется с помощью указателей . Библиотечные функции обработки строки не использовать

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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#include "stdafx.h"
#include "iostream"
using namespace std;
 
//Вводим прототипы 
char* skipspace( char*p); 
int lenght( char*p);
char*Changeline(char*ol);
char*copyword( char*&to, char*&from);
 
 
int _tmain(int argc, _TCHAR* argv[])
{
            char buf [80] ; // создаем буфер на 80 символов
            char c; // переменная выбора
            do 
            {
                cout<< "Enter some simbols: " , cin.getline(buf,80);   // просим пользователя ввести данные
                cout<< "Original line: "<< buf<< ""<< endl; // выводим то что ввел пользователь;
                char*res = Changeline (buf); // изменяем строку
                cout<< "Result: " << res << "" << endl;     // выводим результат    
                cout <<"Would you like to repeat? ( y/n)" << endl; // спрашиваем , хочет ли пользователь повторить
                cin >> c; // считываем значение
            }
            while ( c!='n');
    return 0;
}
 
// Далее идут функции для строк 
//функция пропуска пробела
char*skipspace(char*p) 
{
    while  (*p == ' '|| *p == '\t') // пока пробел или таб 
        ++p; // увеличиваем указатель 
    return p; 
}
 
//=================================================================================================
// Функиция определения длинны строки
int lenght( char*p)
{
    int l = 0; // создаем счетчик
        for (; *p ; ++p, ++l) // пока не конец списка  увеличиваем указатель и счетчик;
            ;
        return l; // возвращаем длину
}
 
//====================================================================================================
// Функция измеения строки
char*Changeline(char*ol)
{
    int l = lenght(ol); // задаем переменной значение длинны строки ( которая была вычесленна ранее)
    char*res= new char[ l+1]; // создали новую строку с длиной l+1  ( отвели 1 для нуль байт)  ( служит для  записи в нее строки без лишних пробелов) 
    char*to= new char[ l+1];  // создаем новую строку с длиной l+1 ( отвели 1 для нуль байт) ( служит для конечной строки с инвертированными буквами)
    while( * (ol = skipspace(ol)) && ol!='\0')  //  пока строка существует и не равна нуль байту 
    {
        to = copyword ( to, ol); // присваеваем to результат функции в которой мы инвертируем слова 
    
    }
        --to; // уменьшаем to 
    *to= '\0'; // записываем нуль байт 
    return res;      // возвращаем строку с перевернутыми словами     
}
//============================================================================================================
// Функция копирования ( ну и сразу замены местами)
char*copyword( char*&to, char*&ol)
{ 
    int i = 0;  // создаем счетчик ( он нам понадобится для определения длины слова) 
    char *buff = ol; // создаем буфер который указывает туда же куда и наша строка без пробелов 
    while (*ol && *ol!= ' ' && *ol!= '\t')  // пока мы не дошли в строке до пробела tab или конца строки 
    {
            *buff++ = *ol++; // увеличиваем указатели 
            i++; 
    }
    buff--;  // уменьшаем buff, тем самым он у нас показывает на последний символ в слове
    while (i > 0 ) 
        {
            i--; // уменьшаем i
            *to = *buff; // to присваеваем то что в buff
            *to++; // переходим к следующему элементу в строке to
            *buff--; // переходим к предыдущему элементу в buff
        }
return to; // возвращаем строку с перевернутым словом
}

предположительно ошибка находится в цикле
C++
1
2
3
4
5
while( * (ol = skipspace(ol)) && ol!='\0')  //  пока строка существует и не равна нуль байту 
    {
        to = copyword ( to, ol); // присваеваем to результат функции в которой мы инвертируем слова 
    
    }
Но как ее исправить не знаю.
Не могли бы помочь в поиске ошибки и ее исправлении. Заранее благодарю)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:32. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru