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

Работа с файлами и строками - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Book http://www.cyberforum.ru/cpp-beginners/thread271948.html
Подскажите пожалуйста книгу по чистому С без объектов и прочего, страниц на 200, что бы легко читалось и было информативно.
C++ Разработка класса Разработать класс описывающий множество точек на плоскости, определить для экземпляров класса операцию объединения множество и операция пересечение множеств. Реализовать метод возвращающий периметр многоугольника покрывающий все множество точек и имеющий наименьшую возможную площадь. Предусмотреть возможность выборам пользователя определение типа данных для координат. P.S. Каждый элемент... http://www.cyberforum.ru/cpp-beginners/thread271795.html
C++ Как созадть такой экземпляр?
Пусть есть класс: class A { protected: type field; .... }; а выше описан тип (возможно класс, или структура) type, или макрос type - синоним существующего (возможно стандартного) типа. В классе нет открытых членов, прямо, или косвенно пишуших член field. Как создать экземпляр класса A с определённым значением члена field?
Что такое инстанцирование? C++
class A { ... }; A a; // Это уже инстанцирование A?
C++ Перегрузка операторов http://www.cyberforum.ru/cpp-beginners/thread271605.html
Расскажите пожалуйста про перегрузку в классе: всегда ли в ней должен быть return и что в нём должно быть её типы(void, int, и т.д.) и почему ставят * или & как вызывать двойные операторы (++, --, +=, и т.д.) можно ли сделать её к пустому типу? Напр. конструкция b+; И можно ли её сделать наоборот? Напр. конструкция +b;
C++ Проверить, является ли введенная с клавиатуры квадратная матрица "магическим" квадратом Написать программу, которая проверяет, является ли введенная с клавиатуры квадратная матрица "магическим" квадратом. "Магическим" квадратом называется матрица, у которой сумма чисел каждом горизонтальном ряду, в каждом вертикальном и по каждой из диагоналей одна и та же приведенный ниже рисунок). Размер матрицы 3х3. 2 9 4 7 5 3 6 1 8 Решить надо через Си Указатель Динамика плиз!! ... подробнее

Показать сообщение отдельно
craftsman
 Аватар для craftsman
0 / 0 / 0
Регистрация: 25.11.2010
Сообщений: 16
07.04.2011, 18:55     Работа с файлами и строками
Здравствуйте. Помогите пожалуйста с решением.
ЗАДАНИЕ: Дан текстовый файл содержащий строки. Занести эти строки в другой текстовый файл,
отсортировав их по убыванию количества слов заданной длины не содержащих цифр.
Длина слова вводится с клавиатуры.
Использовать только библиотеки "iostream.h" и "fstream.h", а также возможно и ""conio.h".
Нужно сделать с использованием функций, указателей и с выделением(удалением) динамической памяти.
Вот есть решение, но слишком сложное, помогите сделать по-проще, как в задании.
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
#include <iostream>
#include <fstream>
#include <vector>
#include <sstream>
using namespace std;
typedef vector<string> StringVector;
 
int main()
{   ifstream fin("in.txt");
    ofstream fout("out.txt");
    int n;
    string s;
    fin >> s;
    n = atoi(s.c_str());
    StringVector lines;
    while( !fin.eof() )
    {   getline(fin,s);
        lines.push_back(s); }
    int p = lines.size();
    int *a = new int[p];
    int *b = new int[p];
    for(int i = 1; i < p; i++)
        b[i] = i;
    for(int i = 1; i < p; i++)
        a[i] = NumOfWords(lines[i],n);
    sort(a,p,b);
    for(int i = 1; i < p; i++)
        fout << lines[b[i]] << endl;
    delete [] b;
    delete [] a;
    return 0;}
 
 
int NumOfWords(string s, int n)
{   int k = 0;
    string::iterator i;
    char elem;
    string word;
    int m = 0;
    for(i = s.begin(); i < s.end(); i++)
    {   elem = *i;
        if( elem != ' ' && ( (int)elem < 48 || (int)elem > 57 ) )
        else if(elem == ' ')
        {   if(m == n) k++;
            m = 0;}}
    if(m == n) k++;
    return k;}
 
void sort(int* a, int p, int* b)
{   for(int i = 1; i < p-1; i++)
        for(int j = i+1; j < p; j++)
            if(a[i] < a[j])
            {   int t = a[i];
                a[i] = a[j];
                a[j] = t;
                int r = b[i];
                b[i] = b[j];
                b[j] = r;}}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 16:08. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru