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

Перенос буквы в конец слова - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Как определить пересечение 2-х треугольников в трехмерном пространстве? http://www.cyberforum.ru/cpp-beginners/thread612174.html
Собсно сабж) Какие есть идеи?
C++ Шифрование графического файла Здрасти.. Идея просто зашифровать считанный граф файл блочным симметричным алгоритмом. int inf=1000000; void __fastcall TForm1::Button5Click(TObject *Sender) { String s2,s1; s1=Edit2->Text; s2=Edit3->Text; //FILE *fp1; ifstream infile (s2.c_str(),ios::binary|ios::in); http://www.cyberforum.ru/cpp-beginners/thread612166.html
C++ Шаблон класса Node для узла связного списка
Здравствуйте, помогите пожалуйста реализовать и протестируйте функцию: template <class T> Node<T> *GetNode(const T &item, Node<T> *nextPtr = NULL); создающую в динамической памяти узел-объект класса Node с данным item и указателем на следующий узел nextPtr. nodelib.h template <class T> class Node { private:
Задача по одномерным массивам C++
Помогите плиз решить задачу по одномерным массивам в C++ "Дан массив целых чисел из n элементов. Найти удвоенную сумму положительных элементов. Подсчитать количество элементов массива, не превосходящих по модулю заданного числа В. Заменить нулевые элементы массива единицами." заданий очень много, не успеваю всё решить...
C++ алгоритмом Определить номера строк, в которых первый элемент равен последнему http://www.cyberforum.ru/cpp-beginners/thread612124.html
Помогите с алгоритмом Вот сама задача: Дана матрица размером МxN. Определить номера строк, в которых первый элемент равен последнему. Тут все понятно, кроме одного где строка у матрицы МxN(M- столбец или N- Строка или наоборот). и последний элемент это будет j-n ? так что ли ?
C++ Наследование шаблонов Не вижу, в чём ошибка. В дочернем классе ругается, что переменная val не определена... Я неправильно делаю наследование? template <class elementType> class Base { protected: elementType val; }; template <class elementType> подробнее

Показать сообщение отдельно
Larkin888
0 / 0 / 0
Регистрация: 17.05.2012
Сообщений: 42
23.06.2012, 12:17     Перенос буквы в конец слова
В произвольном тексте (взятом из файла), содержащем не более 10 строк, в каждой строке не более 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
#include <stdio.h>
#include <ctype.h>
#include <string.h>
 
#include <iostream>
#include <fstream>
 
#define N 10
 
typedef struct Lines
{
    char line[80];
    int count;
} LINE;
 
void swap(LINE& line1, LINE& line2);
 
using namespace std;
 
int main()
{
    const char* filename = "d:\\input.txt";
    ifstream ifs(filename, ifstream::in);
 
    static char* line = new char[80];
    LINE* pText = new LINE[N]; int i = 0;
    memset((void*)pText, 0x00, sizeof(LINE) * N);   
    while ((ifs.peek() >= 0) && (ifs.getline(line, 80)))
    {
        pText[i].count = 0;
        strcpy(pText[i++].line, line);
    }
 
    for (int s = 0; strcmp("\0",pText[s].line) < 0; s++)
    {
        int cnt = 0; char* psz = pText[s].line;
        for (int i = 0; psz[i] != '\0'; i++)
            if (isspace(psz[i]) || i == strlen(psz)-1)
            {
                int k = i-1; int q = strlen(psz)-1;
                while (q >= i) psz[q+1] = psz[q--];
                while ((!isspace(psz[k])) && (k >= 0)) k--;
 
                char ch = psz[k+1]; cnt++;
                for (int n = k+1; psz[n] != '\0'; n++)
                    psz[n] = psz[n+1]; 
                
                psz[i == strlen(psz)-1 ? i : i-1] = ch;
            }
 
            pText[s].count = cnt;
    }
 
    for (int i = 0; strcmp("\0",pText[i].line) < 0; i++)
    {
        int max_i = i;
        for (int k = i+1; strcmp("\0",pText[k].line) < 0; k++)
            if (pText[k].count > pText[max_i].count) max_i = k;
        swap(pText[i],pText[max_i]);
    }
 
    for (int i = 0; strcmp("\0",pText[i].line) < 0; i++)
        printf("%s %d\n",pText[i].line,pText[i].count);
 
    return 0;
}
 
void swap(LINE& line1, LINE& line2)
 { LINE _tl = line1; line1 = line2; line2 = _tl; }
Миниатюры
Перенос буквы в конец слова  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:57. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru