1 / 1 / 2
Регистрация: 27.10.2009
Сообщений: 109
1

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

10.03.2013, 17:42. Показов 555. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем привет! Помогите исправить ошибку.

Условие программы: "Сформировать списки 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); 
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.03.2013, 17:42
Ответы с готовыми решениями:

Формирование двух новых списков из исходного
Доброго времени суток. Задание такое: Структура: список однонаправленный. Реализовать функции:...

Формирование таблицы на основе списков
Задание такое: Сформировать таблицу из списка. Массив в данной программе является Индексом. Т.е...

Быстрое формирование списков большого количество данных
Здравствуйте ув.Форумчане. У меня вот такой вопрос: необходимо сделать быстрое формирование...

Обработка соответствующих элементов двух списков и формирование третьего
Даны два списка одинаковой длины. Получить третий список, каждый элемент равен 1, если элементы...

3
138 / 132 / 57
Регистрация: 31.01.2012
Сообщений: 435
10.03.2013, 17:52 2
IAmHated, у вас там похоже русская буква "о" в объявлении переменной
и еще здесь
C++
1
done = true;
0
1 / 1 / 2
Регистрация: 27.10.2009
Сообщений: 109
10.03.2013, 17:59  [ТС] 3
Черный ворон, да вроде по-английски всё
0
138 / 132 / 57
Регистрация: 31.01.2012
Сообщений: 435
10.03.2013, 18:21 4
IAmHated, проверьте еще раз. я бы не был столь уверен. ошибки до исправления русской буквы и удачная компиляция после прилагаются
Миниатюры
Задача на формирование списков   Задача на формирование списков  
1
10.03.2013, 18:21
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.03.2013, 18:21
Помогаю со студенческими работами здесь

Организовать ввод и формирование двух вещественных списков с проверкой. Найти их объединение без повторов
Организовать ввод и формирование двух вещественных списков с проверкой. Найти их объединение без...

Задача на объедение списков
Здравствуйте. Помогите пожалуйста с решение задачи на lisp - &quot;Определить функцию, которая соединяет...

Задача на объединение списков
Даны 2 списка. Объединить в результирующий список все элементы первого списка и те элементы...

Задача: список списков
Помогите решить задачу, пожалуйста! Turbo Prolog 2.0. Сформировать список L1 из списков: L, L...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru