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

Как прочитать весь файл? - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Структура абитуриент, осталась одна ошибка http://www.cyberforum.ru/cpp-beginners/thread594809.html
1. Структура "Абитуриент": - фамилия, имя, отчество; - год рождения; - оценки вступительных экзаменов (3); - средний балл аттестата. Удалить элемент с указанным номером, добавить элемент после элемента с указанной фамилией #include "iostream" #include <stdio.h>
C++ Сформировать идеально сбалансированное бинарное дерево Дан текст программы. Проверти правильно или нет описание сделал? TNode* makePerfectBalancedTree(int n, TNode* p) // происходит формирование дерева { TNode *r; //тк TNode* r объект используемые для построения геометрической иерархии int nl, nr; // вводим правое и левое значение поддерева if(n == 0) // если n=0 { p = NULL; //переменной p присваивают значение нулл пустое... http://www.cyberforum.ru/cpp-beginners/thread594774.html
Оптимизация времени выполнения C++
Доброго времени суток. Есть следующая задача. Задача олимпиадная, потому учитывается время выполнения, нужно вложится в 1секунду. Мой код на сервере работает 1,014 с. Никак не могу уменшыть время выполнения. Помогите кто может. Условие и мой код ниже. Последовательность an задается следующей формулой: an = n2 mod 12345 + n3 mod 23456. Требуется много раз отвечать на запросы следующего...
C++ Пpи помощи стека пpовести соpтиpовку
Дан файл, элементами котоpого являются целые числа, упоpядоченные по возpастанию (убыванию). Пpи помощи стpуктуpы данных стек пpовести "обpатную" соpтиpовку файла по убыванию (возpастанию!)
C++ Вывести числа в порядке убывания, вычислить площадь треугольника http://www.cyberforum.ru/cpp-beginners/thread594743.html
Проверить задачу если возможно - собственно прошу вас посмотреть эту задачу. Условие: Ввести три числа. Если они могут быть длинами сторон тупоугольного треугольника, вывести их в порядке убывания, вычислить площадь полученного треугольника. Нашел подобную задачу, и в ообщем намудрил чет. #include<iostream> #include<clocale> #include <math.h>
C++ Как записать ответ с методом пузырька? Собственно програмка выдает около 100 разных значений, как можно было бы записать их методом пузырька в массив? Или еще лучше, если бы, например у нас есть ответ, 2 параметра результата, например "s=100 v=10; s=30 v=12....s=55 v=33; s=33 v=11" вот отсартировать по S, что бы получилось 100 55 33 30 , а уже к ним, хоть отдельной строкой 10 33 11 12, последовтельно Можно код, пожалуйста? подробнее

Показать сообщение отдельно
Andreu135
0 / 0 / 0
Регистрация: 01.06.2012
Сообщений: 7
03.06.2012, 18:05  [ТС]     Как прочитать весь файл?
Спасибо, эта конструкция помогла, файл читается, но вот если в файле 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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <iterator>
#include <iostream>
#define IFNAME "laba7.txt"
#include <locale>
#include <windows.h>
#define BSIZE 1024
using namespace std;
 
string sorting(string str)
{
int k=0;
//считаем пробелы
 for(int i=0;i<str.length();i++) if(str[i]==' ') k++;
 string *words = new string[k+1];
 
k=0;
int word_begin=0,word_end=0;
//заполняем массив строк
for (int i=0; i<str.length();i++)
  {
    if(str[i]==' ' || i==str.length()-1)
    {
      word_end=i;
      for(int j=word_begin;j<word_end;j++) words[k]+=str[j];
      k++;
      word_begin=word_end+1;
    }
  }
// сортируем массив строк
string tmp="";
for(int i=0;i<k;i++)
  for(int j=i;j<k;j++)
    if(words[i]>words[j])
      {
         tmp=words[i]; 
         words[i]=words[j];
         words[j]=tmp;
       }
str="";
//вставляем отсортированный вариант в исходную строку(теперь можно из маина просто считать строку, вызвать функцию и вывести строку, уже отсортированную)
for(int i=0;i<k;i++)
str+=words[i]+ " ";
return str;
}
 
int main()
{
    FILE* pf = fopen("laba7.txt", "r");
    if(pf)
    {
        char buf[BSIZE], *p(buf);
        for(; (p - buf < BSIZE - 1) &&(*p = fgetc(pf)) && !feof(pf); ++p);
        *p = 0;
        std::string s(buf);
        s=sorting(s);
        cout << s;
        cout<<endl;
        fclose(pf);
    }
    else perror("fopen failed\n");
    cout<<endl;
    system("pause");
    return 0;
}
 
Текущее время: 10:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru