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

Перегрузка оператора индексации для класса плохо себя ведёт - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Удаление подстроки http://www.cyberforum.ru/cpp-beginners/thread1012036.html
Здравствуйте. Подскажите пожалуйста что нужно исправить в проге, которая является решением данной задачи: Даны строки S1 и S2. Удалить из строки S1 последнюю подстроку, совпадающую с S2. Если совпадающих подстрок нет, то вывести строку S без изменений. У меня удаляется первая, а не последняя подстрока: #include <stdio.h> #include <string.h> #include <conio.h> void main() { char s1,...
C++ xCode и файлы Доброго времени суток уважаемые форумчане. Я изучаю с++ на macOS и использую их среду разработки xCode. С ним у меня возникла следующая проблема #include <iostream> #include <fstream> #include <vector> using namespace std; int main () { bool eror = false; /* setlocale(LC_ALL, "Russian");*/ http://www.cyberforum.ru/cpp-beginners/thread1012016.html
массивы. в чем ошибка? C++
#include<iostream> #include<iomanip> #include<math.h> #include<conio.h> #include<String.h> #include<ctype.h> #include<stdlib.h> #include<windows.h> #include<fstream> using namespace std;
Цикл C++
Добрый день. Как достать среднюю цифру трехзначного числа? первая int firstDigit = 370; while (firstDigit >= 10) { firstDigit /= 10; }
C++ Лафоре. Глава 11. Задача 2 http://www.cyberforum.ru/cpp-beginners/thread1012009.html
Решал задачку из учебника - Лафоре. Глава 11. Задача 2. Вот код #include <iostream> #include <iomanip> #include <conio.h> using namespace std; class publication {
C++ Хеш-таблица Решить следующую задачу с использованием структуры «Словарь» на основе хэш-таблицы. Разработать программу обработки складской ведомости учета прихода и расхода товаров. В каждой строке ведомости содержится артикул товара и количество поступивших/выданных единиц товара. Например, 12221 4 45555 3 12221 -3 45555 2 45555 -5 По результатам обработки ведомости программа должна предоставлять... подробнее

Показать сообщение отдельно
k1-801
 Аватар для k1-801
4 / 4 / 2
Регистрация: 07.01.2013
Сообщений: 135
19.11.2013, 16:55  [ТС]     Перегрузка оператора индексации для класса плохо себя ведёт
Некогда код дорезать, вот.
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
#include <iostream>
#include <stdio.h>
#include <vector>
#include <algorithm>
#include <string>
#include <queue>
#include <set>
#include <math.h>
#include <fstream>
using namespace std;
 
class word
{
    public:
        string en_name;
        //no more code yet
};
 
bool __base_sort_word_comparator(word _f, word _s)
{
    return _f.en_name<_s.en_name;
}
 
class base
{
    public:
        char *base_filename;
        fstream b_file;
        vector <word> _b;
        bool load(char* _b_filename)
        {
            base_filename=_b_filename;
            b_file.open(base_filename);
            if(b_file)
            {
                //here is scanning code;
            }
            return (b_file);
        }
        word& get(unsigned int n)
        {
            return _b[n];
        }
        void clear()
        {
            _b.clear();
            b_file.close();
            return;
        }
        void reload()
        {
            _b.clear();
            return;
        }
        long long size()
        {
            return _b.size();
        }
        void sort()
        {
            std::sort(_b.begin(),_b.end(),__base_sort_word_comparator);
            return;
        }
        void save(char *s_fn)
        {
            ofstream s_file;
            s_file.open(s_fn);
            long long i;
            for(i=0;i<_b.size();i++)
                s_file<<0;
            s_file.close();
            return;
        }
        void save()
        {
            save(base_filename);
            return;
        }
        word& operator [] (unsigned int n)
        {
            return get(n);
        }
};
 
Текущее время: 16:09. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru