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

Задача на формирование списков - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Из массива строк выделить подстроки состоящие из русских букв, затем найти среди них самую котороткую http://www.cyberforum.ru/cpp-beginners/thread804805.html
Продолжение задания: В строке, содержащей самую коротку подстроку(из условия) - русские буквы в конце. Помогите пожалуйста дописать эту прогу. #include <stdio.h> #include <ctype.h> #include <string.h> #include <iostream> using namespace std;
C++ Дан массив целых чисел. Найти В этом массиве минимальный элемент т и максимальный элемент м. Вывести сумму элементов от минимального до максимального Дан массив целых чисел. Найти В этом массиве минимальный элемент т и максимальный элемент м. Вывести сумму элементов от минимального до максимального элемента не включая их. http://www.cyberforum.ru/cpp-beginners/thread804799.html
C++ Указатель на объект с перегруженным оператором вывода(с наследованием)
Есть два класса: строка(базовый) и комплексное число(производный). В базовом классе есть поле stri (указатель на char). В производном классе есть перегруженный оператор вывода для этого поля. Как следует написать этот оператор(или что-либо ещё изменить), чтобы он выдавал на экран stri, а не адрес памяти? #include "stdafx.h" #include "iostream" using namespace std; int ck=0,cf=0;
Чем заголовочные файлы отличаются от обычных бибилиотек? C++ C++
вроди как это одной и тоже, только в стандартной библиотеки C все файлы заголовочные, а в C++ обычные библиотеки... В чем разница между ними, ведь и там и там лежат подобные сущности.
C++ Ругается компилятор http://www.cyberforum.ru/cpp-beginners/thread804763.html
Создать класс жидкость, имеющий название (указатель на строку), плотность. Определить конструкторы, деструктор и операторы вывода в поток. Создать производный класс - спиртные напитки, имеющий крепость. Определить функции переназначения плотности и крепости. Продемонстрировать работу классов. #include <iostream> class jidkost { public: jidkost(char *Njid, double Pjid); protected: char...
C++ Найти количество действительных корней квадратного уравнения не могу найти ошибку.Компилятор ругается Суть задачи : Определить кол-во действительных корней квадратного уравнения ax^2+bx+c=0 с произвольными значениями a,b,c. #include <iostream> #include <math.h> void main() double a,b,c,d,x1,x2; std::cout<<"Vvedi koeficienti a,b,c"; std::cin>>a; std::cin>>b; подробнее

Показать сообщение отдельно
IAmHated
1 / 1 / 0
Регистрация: 27.10.2009
Сообщений: 108
10.03.2013, 17:42     Задача на формирование списков
Всем привет! Помогите исправить ошибку.

Условие программы: "Сформировать списки L1 и L2 из списка L по следующему правилу: в L1 четные положительные элементы списка L, в L2 - нечетные отрицательные элементы списка L."

Ошибку выдает в это строчке (error C2065: done: необъявленный идентификатор):
C++
1
while (!done);
Собственно сама программа:
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
#include "stdafx.h"
#include <windows.h>
#include <iostream>
#include <iomanip>
#include <locale>
#include <stdio.h>
#include <cstdlib>
#include <cstring>
#include <sstream> 
#include <list> 
using namespace std; 
 
template <class T, bool Predicate(T x)> 
void filter(const list<T> & source, list<T> & result) 
{ 
for (list<T>::const_iterator i = source.begin(); i != source.end(); i++) 
{ 
T item = *i; 
if (Predicate(item)) 
result.push_back(item); 
} 
} 
 
bool is_positive_even(int x) 
{ 
return (x > 0) && (x % 2 == 0); 
} 
 
bool is_negative_odd(int x) 
{ 
return (x < 0) && (x % 2 != 0); 
} 
 
template <class T> 
void print_list(const string & name, const list<T> & list_) 
{ 
cout << name << " (" << list_.size() << " items): "; 
 
bool is_first_item = true; 
for (list<T>::const_iterator i = list_.begin(); i != list_.end(); i++) 
{ 
if (is_first_item) 
is_first_item = false; 
else 
cout << " "; 
 
cout << *i; 
} 
 
cout << endl; 
} 
 
void _tmain() 
{ 
list<int> source; 
bool dоne = false; 
do 
{ 
char buff[255]; 
cin.getline(buff, sizeof(buff) / sizeof(*buff)); 
 
string line(buff); 
if (line.length() == 0) 
dоne = true; 
else 
{ 
istringstream stream(line); 
int item = 0; 
 
stream >> item; 
if (!stream.fail()) 
source.push_back(item); 
} 
} 
while (!done); 
 
list<int> list1; 
filter<int, is_positive_even>(source, list1); 
 
list<int> list2; 
filter<int, is_negative_odd>(source, list2); 
 
print_list<int>("L", source); 
print_list<int>("L1", list1); 
print_list<int>("L2", list2); 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 21:22. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru