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

Добавить элементы в очередь - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Подскажите где ошибка в классе http://www.cyberforum.ru/cpp-beginners/thread858184.html
вот сам класс #include <iostream> #include <stdlib.h> #include <iomanip> #include <time.h> #include <string> using namespace std; // использую потому что нет риска пересечения пространства имен. class Fight{
C++ Передача динамического массива в функции #include <iostream> #include <cstdlib> using namespace std; /*const*/ int k=3; //void sum (int mas); void sum (int * arr, int k, int t); //void max(int matrix); void max(int * arr ,int g, int r); http://www.cyberforum.ru/cpp-beginners/thread858170.html
Подсчитать количество слов,начинающихся с указанной буквы C++
Ребят,помогите пожалуиста. вот ,есть задачка: Дан текст произвольной длины,оканчивающийся точкой.текст состоит из слов,разделенных пробелами.Подсчитать количество слов,начинающихся с указанной буквы; Я программку написала,он считает слова,а главного условия,т.е счичать не все слова,а именно,с указанной буквы,не считает вот сама прога: #include <stdio.h> #include<string.h> enum{OUT,IN};...
C++ Найти максимальное и минимальное значение функции
Просьба решить задачку, так как я сам ни бум бум...=( А через пару недель нужно перездать зачет. Очень прошу помочь!! Составить таблицу значений заданной функции. Найти максимальное и минимальное значение функции, соответствующие им значения аргументов для каждого значения параметра. Шаг изменения аргумента и параметра студент выбирает самостоятельно так, чтобы число значений параметров было...
C++ Реализация семафоров http://www.cyberforum.ru/cpp-beginners/thread858153.html
Возможно ли реализовать семафоры вручную или же для этого нужна обязательная поддержка процессора?
C++ Как распарсить строку и положить данные в элементы структуры Здравствуйте! Интересует следующий вопрос. У нас есть есть строка. Например, ab|ac|ad|ae|af|ag|ah. И есть структура -> struct table { string ab, ac, ad, ae, af, ag, ah; }; Задача состоит в том, чтобы из строки вытащить значения, какими являются ab, ac, .., ah. Я написал кусок кода, который вытаскивает эти значения. Но т.к. это дело происходит в цикле, я не могу на каждом шаге записать... подробнее

Показать сообщение отдельно
lemegeton
 Аватар для lemegeton
2910 / 1339 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
07.05.2013, 13:39     Добавить элементы в очередь
Странный у вас код. Ещё не класс, но и уже не простая структура...
Обозначьте хоть условие задачи и ограничение на инструменты.

Ну или вот вам велосипед с примером.
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
#include <iostream>
 
template <class T>
class Queue {
 public:
  Queue(size_t capacity) : first(0), last(0), capacity(capacity),
    data(new T[capacity]) {}
  Queue(const Queue &other) : data(0) {
    copyFrom(other);
  }
  Queue &operator=(const Queue &other) {
    return copyFrom(other);
  }
  virtual ~Queue() {
    delete [] data;
  }
  void pushBack(const T &value) {
    data[last % capacity] = value;
    last = (last + 1) % (2 * capacity);
  }
  void popFront() {
    first = (first + 1) % (2 * capacity);
  }
  void clear() {
    first = last = 0;
  }
  const T &getFront() const {
    return data[first % capacity];
  }
  const T &getBack() const {
    return data[(last - 1) % capacity];
  }
  size_t getSize() const {
    return last - first;
  }
  bool isEmpty() const {
    return last == first;
  }
  size_t getCapacity() const {
    return capacity;
  }
  size_t getMaximumCapacity() const {
    return (size_t)(-1) / 2;
  }
  Queue &copyFrom(const Queue &other) {
    if (this != &other) {
      delete [] data;
      first = other.first;
      last = other.last;
      capacity = other.capacity;
      data = new T[capacity];
      for (size_t i = first; i != last; ++i) {
        data[i % capacity] = other.data[i % capacity];
      }
    }
    return *this;
  }
 private:
  size_t first;
  size_t last;
  size_t capacity;
  T *data;
};
 
int main(int argc, char *argv[]) {
  Queue<int> q(10);
 
  for (size_t i = 0; i < q.getCapacity(); ++i) {
    q.pushBack(i);
  }
 
  Queue<int> a(q);
 
  while (!a.isEmpty()) {
    std::cout << a.getFront() << std::endl;
    a.popFront();
  }
 
}
 
Текущее время: 22:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru