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

Создание класса путем наследования - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Массив: Найти такую неразрывную последовательность положительных чисел, сумма элементов у которой максимальная. http://www.cyberforum.ru/cpp-beginners/thread834860.html
Найти такую неразрывную последовательность положительных чисел, сумма элементов у которой максимальная. ну вот я сделал, но только будет работать, если есть только один отрицательный элемент. #include<iostream> #include<conio.h> using namespace std; int main() { const int n=8;
C++ C++11 новые классы стандартной библиотеки Здравствуйте. Программирую в eclipse на С++, использую С++11. Код в новом стандарте компилируется, однако мне нужен новый класс initializer_list (+ ещё другие новые классы). Посмотрел, что сам заголовочный файл есть в системе. Директива include его находит. Однако std::initializer_list не воспринимает, пишет что-то вроде "нет такого элемента в пространстве имён". Кроме этого, не видит конструктор... http://www.cyberforum.ru/cpp-beginners/thread834844.html
Инлайн-функция замедляет работу C++
Здравствуйте! видимо что-то делаю неправильно...имею код. Запускаю скомпилированную программу - работает с одной скоростью. Копипастю код в инлайн функцию - скорость выполнения резко уменьшается. если кому интересно - вот начальный код // Task3.cpp: определяет точку входа для консольного приложения. // #include <stdlib.h> #include <math.h> #include <sys/time.h> #include <iostream>...
Даны шесть различных чисел. Определить максимальное из них C++
Даны шесть различных чисел. Определить максимальное из них. (Определить функцию, находящую максимум из двух различных чисел.) Еще одна подобная тема, и последуют санкции.
C++ Выяснить является ли хоть одно из данных чисел палиндромом(перевёртышем) http://www.cyberforum.ru/cpp-beginners/thread834825.html
Даны 2 натуральных числа выяснить является ли хоть одно из них палиндромом(перевёртышем) тоесть таким числом десятичная запись которого читается одинаково слева на право и справо на лево.(определить функции позволяющие распозновать числа палиндромы)
C++ Лучшие ресурсы в Интернет - разработчикам C++ Все источники широко известны - но тем не менее: http://strongcpp.blogspot.ru/2013/04/c.html подробнее

Показать сообщение отдельно
stima
430 / 285 / 16
Регистрация: 22.03.2011
Сообщений: 928
Завершенные тесты: 1
17.05.2013, 17:57     Создание класса путем наследования
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
#include <cstdlib>
#include <cstring>
#include <cassert>
#include <cstdio>
 
class File
  {
  public:
    File();
    File(const char* name, const char* mode);
 
    virtual ~File();
 
    void open(const char* name, const char* mode);
    void close();
 
    void read(void* buff, size_t size_of_elem, size_t count);
    void write(const void* buff, size_t size_of_elem, size_t count);
 
    int seek(long offset, int origin);
 
    int get_length();
 
    bool is_open() const { return _is_open; }
    const char * const name() const { return _name; }
 
  private:
    char *_name;
    bool _is_open;
    FILE *p_file;
 
    char* _cpy_name(const char* src);
    bool _open(const char* name, const char* mode);
  };
 
File::File()
  : _name(0) {}
 
File::File(const char* name, const char* mode)
  {
  _name = _cpy_name(name);
  _is_open = _open(_name, mode);
  }
 
File::~File()
  {
  close();
  if (_name) free(_name);
  }
 
void File::open(const char* name, const char* mode)
  {
  _name = _cpy_name(name);
  _is_open = _open(_name, mode);
  }
 
void File::close()
  {
  if (p_file)
    {
    fclose(p_file);
    p_file = 0;
    }
  }
 
char* File::_cpy_name(const char* src)
  {
  char *name = (char*)malloc((strlen(src) + 1) * sizeof(char));
  assert(name);
  
  strcpy(name, src);
  return name;
  }
 
bool File::_open(const char* name, const char* mode)
  {
  p_file = fopen(name, mode);
  return p_file;
  }
 
void File::read(void* buff, size_t size_of_elem, size_t count)
  {
  fread(buff, size_of_elem, count, p_file);
  }
 
void File::write(const void* buff, size_t size_of_elem, size_t count)
  {
  fwrite(buff, size_of_elem, count, p_file);
  }
 
int File::seek(long offset, int origin)
  {
  return fseek(p_file, offset, origin);
  }
 
int File::get_length()
  {
  seek(0, SEEK_END);
 
  int len = ftell(p_file);
  rewind(p_file);
 
  return len;
  }
 
class GoodFile : public File
  {
  public:
    GoodFile() {}
    GoodFile(const char* name, const char* mode)
      : File(name, mode) {}
 
    //dont read bad things:)
    void read(char* buff, size_t count)
      {
      char *tmp = (char*)malloc((count + 1)* sizeof(char));
 
      memset(tmp, 0, count + 1);
      memset(buff, 0, count);
 
      File::read(tmp, sizeof(char), count);
 
      char *pos = strstr(tmp, "bad");
      if (!pos)
        {
        strcpy(buff, tmp);
        free(tmp);
 
        return;
        }
      
      int i_pos = pos - tmp;
      memcpy(buff, tmp, i_pos);
 
      char *s1 = buff + i_pos;
      char *s2 = tmp + i_pos + strlen("bad") + 1;
 
      memcpy(s1, s2, strlen(s2));
 
      free(tmp);
      }
  };
 
int main()
  {
  GoodFile file("file.txt", "w");
 
  if (!file.is_open())
    return 1;
 
  char str[] = "Hello bad world!";
  int len = strlen(str);
 
  file.write(str, sizeof(char), len);
 
  str[0] = 0;
  file.close();
 
  file.open("file.txt", "r");
  file.read(str, len);
 
  printf("%s", str);
 
  getchar();
 
  return 0;
  }
 
Текущее время: 22:12. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru