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

символ конца файла - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Кодировки, вывод/ввод на консоль и в файл http://www.cyberforum.ru/cpp-beginners/thread861010.html
Помогите разобраться с кодировками, а то я в этом вопросе не очень разбираюсь. Не получается одновременно сделать правильный ввод и вывод в одной программе, все известные мне методы я уже перепробовал. Вот код:#include <iostream> #include <string> #include <fstream> #include <windows.h> int main () { //SetConsoleCP (1251); SetConsoleOutputCP (1251); //строки wstring вообще не выводит...
C++ Сортировка массива объектов класса Пишу программу в которой есть массив объектов и методы которые его сортируют, но после сортировки ничего не выводится, а просто чистое консольное окно, помогите разобраться TMagnitafon.h #pragma once #include "string.h" class TMagnitafon { public: char pType; char pFirma; http://www.cyberforum.ru/cpp-beginners/thread861002.html
C++ Запись кириллицы в строку из консоли
Столкнулся с такой проблемой: если я пытаюсь заполнить строку из консоли, то потом из этой строки на экран выводятся кракозябры. Подскажите, пожалуйста, как сделать, чтобы все было нормально? int _tmain(int argc, _TCHAR* argv) { setlocale (LC_ALL,"rus"); string str; char tmp; cout<<"Введите, что вы хотели бы вывести на экран: "; getline(cin,str); cout<<str<<endl; system...
Наибольшее расстояние между словами в файле C++
Полный текст задачи: Дан файл, содержащий текст на русском языке и некоторые два слова. Определить, сколько раз они встречаются в тексте и найти наибольшее расстояние между этими словами.(сколько слов между ними). Добавлено через 8 минут #include<fstream> #include<iostream> #include<string> #include<conio.h> #include<stdio.h> #include <sstream> #include <locale.h>
C++ Считывание из файла http://www.cyberforum.ru/cpp-beginners/thread860970.html
Всем привет! Есть вот такая проблема: при считывании данных из файла в объект ниоткуда берутся лишние данные. В чем может быть проблема? Вот пример файла: 1 1 1 2 2 2 А вот что получается когда считываю файл: 1 1 1 2 2 2 2 2 void output(Toys &T) { ifstream in("1.txt");
C++ в чем ошибка? Дано целое позитивное число n. Составить алгоритм вычисления суммы В чем ошибка в коде?#include <iostream> #include <conio.h> #include <math.h> #include <locale.h> using namespace std; //главная функция программы, с нее начинается выполнение int main() подробнее

Показать сообщение отдельно
Levenyatko
2 / 2 / 0
Регистрация: 05.07.2012
Сообщений: 99
11.05.2013, 17:20  [ТС]     символ конца файла
stima,

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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <map>
#include <list>
#include <fstream>
using namespace std;
 
class Node
{
    public:
     int Frequency;
     char Symbol;
     Node *left, *right;
     
     Node(){left=right=NULL;}
 
     Node(Node *L, Node *R) 
     {  left =  L;
        right = R;
        Frequency = L->Frequency + R->Frequency; 
     Symbol = NULL;
     }
};
 
 
struct MyCompare
{
    bool operator()(const Node* l, const Node* r) const { return l->Frequency < r->Frequency; }
};
 
 
vector<bool> code;                
map<char,vector<bool> > table;    
 
map<char, int> one;
 
void BuildTable(Node *root)
{   
    if (root->left!=NULL) 
                      { code.push_back(1);
                      BuildTable(root->left);}
     
    if (root->right!=NULL)
                       { code.push_back(0);
                       BuildTable(root->right);}
   
    if (root->Symbol) table[root->Symbol]=code;     
    
    code.pop_back();
}
 
 
int main (int argc, char *argv[])
{
    setlocale(LC_ALL,"rus");
////// считаем частоты символов 
    
    ifstream f("one.txt");
    
    map<char,int> m;
 
    while (!f.eof())
    { char c = f.get(); 
       m[c]++;}
    
  
////// записываем начальные узлы в список list
    
   list<Node*> t;
   for( map<char,int>::iterator itr=m.begin(); itr!=m.end(); ++itr)
   {  
      Node *p = new Node;
      p->Symbol = itr->first; //cout<<p->c<<"  ";
      p->Frequency = itr->second;//cout<<p->a<<endl;  
      t.push_back(p);      }    
    
 
//////  создаем дерево      
 
  while (t.size()!=1)
  {  
     t.sort(MyCompare());
     /*cout<<"__________"<<endl;
     for(list<Node*>::iterator i= t.begin();i!= t.end();++i)
     {
         cout<<(*i)->a<<(*i)->c<<endl;
     }
     cout<<endl<<endl;
     system("pause");*/
     Node *SonL = t.front();
     t.pop_front();
     Node *SonR = t.front(); 
     t.pop_front();
     
     Node *parent = new Node(SonL,SonR); 
     t.push_back(parent);
 
  }
    
    Node *root = t.front();   //root - указатель на вершину дерева
 
////// создаем пары 'символ-код':           
 
    BuildTable(root);   
        
////// Выводим коды в файл output.txt
 
    f.clear(); f.seekg(0); // перемещаем указатель снова в начало файла
    
    fstream g;
    g.open("output.txt", fstream::out, fstream::binary);
        
    int count=0; char buf=0;
    //вывод пар символ - код
    /*
    for(map<char,vector<bool> >::iterator i = table.begin();i!=table.end();i++)
    { 
        cout<<i->first<<"  ";
        vector<bool> vec = i->second;
        for(vector<bool>::iterator itr=vec.begin();itr!=vec.end();itr++)
            cout<<*itr;
        cout<<endl;
    }*/
    //while (!f.eof())
    while(f)
    { char c = f.get();
      vector<bool> x = table[c];
      for(int n=0; n<x.size(); n++)
       {buf = buf | x[n]<<(7-count);   
        count++;   
        if (count==8) 
        {
        
            count=0;
//          g<<buf;
            g.write(&buf,sizeof(char));
            buf=0; 
        } 
       }
    
   }
    f.close();
    g.close(); 
    
///// считывание из файла output.txt и преобразование обратно
    
    fstream F;
    F.open("output.txt", fstream::in, fstream::binary);
    fstream e;
    e.open("put.txt", fstream::out, fstream::binary);
 
    Node *p = root;
    count=0; char byte; 
    //F>>byte;
    F.read(&byte,sizeof(char));
    
    //while(!F.eof())
    while(F)
    {   
//      bool b = byte & (1 << (7-count) ) ; 
                char b = byte & (1 << (7-count) ) ; 
        if (b) p=p->left; else p=p->right;
        //if (p->left==NULL && p->right==NULL) {cout<<p->c; p=root;}
        if (p->Symbol!=NULL) {e.write(&p->Symbol,sizeof(char)); p=root;}
        count++;
        if (count==8) 
        {
            count=0;
        //  F>>byte;
            F.read(&byte,sizeof(char));
        
        }
    }
    
    F.close();  
    e.close();
    system("pause");
    return 0;
}
 
Текущее время: 17:46. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru