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

Через потоки составить предметный указатель - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Исключить из массива первый положительный элемент, следующий за максимальным http://www.cyberforum.ru/cpp-beginners/thread406319.html
Дан одномерный массив А, состоящий из N элементов.Исключить из массива первый положительный элемент,следующий за максимальным.
C++ подробно обьясните программу плиз #include <iostream> #include <conio.h> #include <fstream> #include <string> #include <iomanip> #include <stdlib.h> #include <stdio.h> #include <math.h> using namespace std; http://www.cyberforum.ru/cpp-beginners/thread406317.html
C++ лабораторная Строки
1. Запишите ФИО . Запишите данную строку в обратном порядке. 2. Запишите ФИО . Удалите все пробелы в данной строке. 3. В тексте заменить все символы 'а' на 'в'. текст Звуки вальсу особливо хвилюють того, хто не вміє танцювати.
Ошибка "Constant expression is required" - const в сlass C++
Создал класс: class TVseGrup { public: TVseGrup(const short KolTo4=0) : FKolTo4(KolTo4) {FKolTo4=0;} const short FKolTo4; int MassivTo4Grup; //вот тут ругается. }; Вроде бы объявил переменную const. Чего ему еще надо, не пойму?!!
C++ Сортировка матрицы http://www.cyberforum.ru/cpp-beginners/thread406313.html
Элементы главной диагонали квадратной матрицы расположить в порядке убывания.
C++ сортировка Помоги доделать программу , сортировать слова по алфавиту , радиксным(распределяющим) методом string radix(string str, int max, int k){ string s1; int i,e,v,q=0; e=0; string s2=""; if(k==1) { подробнее

Показать сообщение отдельно
Влада-Влада
Сообщений: n/a
13.12.2011, 17:17     Через потоки составить предметный указатель
Помогите пожалуйста!
Задачу надо решить через потоки.
Строки текстового файла input.txt состоят из слов, разделенных одним или несколькими пробелами. Перед первым, а также после последнего слова строки пробелы могут отсутствовать. Требуется на основе исходного файла построить предметный указатель и вывести его в файл output.txt. Каждая строка предметного указателя содержит слово и номера строк текстового файла, в которых это слово встречается, разделенные одним пробелом.

Добавлено через 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
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<iostream>
#include<stdio.h>
#include <string.h>
#include<string>
# include<fstream>
using namespace std;
 
int main()
{
    setlocale(LC_ALL,".1251");
    
    const int MAX=300;
    char str[MAX],*word,strw[MAX];
    const char seps[]=" ,.\n\t";
    ifstream in("input.txt");
    fstream out("output.txt",ios::out | ios::in | ios::trunc);
    in.getline(str,MAX);
    if (in.eof())
    {
        cout<<"Файл пустой..."<<endl;
        return 0;
    }
 
    int ns=0,i1=0,i2,pw;
    int inp=0;
    string strws;
    bool b=false;
    while(!in.eof())
    {
        
        inp=in.tellg();
        ns++;
        str[strlen(str)+1]=' ';
        str[strlen(str)+1]='\0';
        word = strtok(str,seps);
        bool t=false;
        if (word)
            b=true;
        while(word)
           {
               out.seekg(0, ios::beg);
               out.getline(strw,MAX);
               while(!out.eof()&&!t)
               { 
                   pw=out.tellg();
                   strws=strw;
                   strws+=" ";
                   string words;
                   int i1=0;i2=0;
                   i2=strws.find_first_of(seps,0);
                   words=strws.substr(0,i2);
                   if(word==words)
                           t=true;
                   out.getline(strw,MAX);
              }
               
               if (!t)
               {
                   out.seekg(0, ios::end);
                   out<<word<<" "<<ns;
                   out<<"          "<<endl;
               }
               else 
               {
                  out.seekg(pw-13,ios::beg);
                   int i=0,ns2=0,k=0;
                   out.getline(strw,MAX);
                   while((strw[k]!=' ')||(strw[k+1]!=' '))
                       k++;
                    out.seekg(pw-13+k,ios::beg);
                    out<<" "<<ns;
               }
               t=false;
              word = strtok(NULL,seps);
            } 
        in.getline(str,MAX);
    }
    if (!b)
        out<<"Все ваши строки состоят только из пробелов."<<endl;
    in.close();
    out.close();
    return 0;
 
}
только оно не выводит результат.
как это исправить?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:32. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru