Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
 Аватар для 123456776
1 / 1 / 0
Регистрация: 09.09.2013
Сообщений: 41

Подскажите, где ошибки в программе

27.10.2013, 21:40. Показов 747. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
#include <conio.h>//підключеннябібліотек
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

class Och//класочередь
{
private://закриті полякласу
struct Node//структура вузол
{
int d;//поле дані
Node *p;//покажчик на кінцевийелемент
};

Node *ft;//перший елемент очереди
Node *last;//останнійелемент очереди
int count;//полелічильник
void add(Node **pend, int d)
{
Node *pv = new Node;
pv->d = d;
pv->p = 0;
(*pend)->p = pv;
*pend = pv;
}
public://поля класу
Och()//конструктор по замовчуванню
{
ft = last = 0;//ініціалізаціязмінних
count = 0;//ініціалізаціязміннихлічильник на нуль
}

Och(int *s)//з параметрами
{
count = 0;//показчик на нуль встановлюємо
Node *p;
add(&p,*s);//додаэмоелемент
}

Och(const Och &sender)//конструкторкопіювання
{
count = 0;//показчик на 0
Node *p;
Node *it = sender.ft;
while(it)//покиіт правда тобто не дорівнює нулю
{
add(&it->p,it->d);//додаємоелемент
}
}
Och * first(int d)
{
Node *pv = new Node;
pv->d = d;
pv->p = 0;
return pv; }
Node &operator + (Node **pend,int pv)//оператордодаваняелементу
{
Node *pv = new Node; //показник
pv->d = d; //двигаємопопередуелемент
pv->p = 0; //а новийставимо на першу позицію
(*pend)->p = pv;
*pend = pv;
}
Node* operator -(Node **pbeg)//видалитиелемент
{
int temp = (*pbeg)->d; //елементзаписуемоякийпотрібенвийти
Node *pv = *pbeg; //записуемо той який стане останнімтобто першим якийвийде
*pbeg = (*pbeg)->p;
delete pv; //видаляємоелементякийвийшов
}

bool operator()(const Och &sender)//оператор перевірки на порожністьчерги
{
Node *it1 = ft;//показчик на 1 елементоб,єкта

if(it1->d != NULL) return true;//якщоякщочерганепуста то повернення 0
return false;//якщо пуста то повернення 1
}
void Print()//вивідчерги на екран
{
Node *it = ft;//поставити на 1 елемент
while(it)//покиит правда
{
printf("%c", it->d);//виводемосимволи з черги
it = it->p;//рухаємося до наступного
}
printf("\n");//перенос строки
}
};


void main()
{
Och *pbeg;
pbeg->first(1); //створеннячерги
Och *pend = pbeg; //початок черги
for (int i = 2; i<6; i++) //
pend +(&pend, i); //додаванняелементу в чергу
while (pbeg)
printf("%d",-(&pbeg)); //видаленняелемента в з черги
_getch();
}
Буду очень благодарна!!!

Добавлено через 52 минуты
Уже такой код:
#include <conio.h>//підключеннябібліотек
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

class Och//класочередь
{
private://закриті полякласу
struct Node//структура вузол
{
int d;//поле дані
Node *p;//покажчик на кінцевийелемент
};

Node *ft;//перший елемент очереди
Node *last;//останнійелемент очереди
int count;//полелічильник
void add(Node **pend, int d)
{
Node *pv = new Node;
pv->d = d;
pv->p = 0;
(*pend)->p = pv;
*pend = pv;
}
public://поля класу
Och()//конструктор по замовчуванню
{
ft = last = 0;//ініціалізаціязмінних
count = 0;//ініціалізаціязміннихлічильник на нуль
}

Och(int *s)//з параметрами
{
count = 0;//показчик на нуль встановлюємо
Node *p;
add(&p,*s);//додаэмоелемент
}

Och(const Och &sender)//конструкторкопіювання
{
count = 0;//показчик на 0
Node *p;
Node *it = sender.ft;
while(it)//покиіт правда тобто не дорівнює нулю
{
add(&it->p,it->d);//додаємоелемент
}
}
Och * first(int d)
{
Node *pv = new Node;
pv->d = d;
pv->p = 0;
return pv; }
Node &operator+ (Node **pend,int pd)//оператордодаваняелементу
{
Node *pv = new Node; //показник
pv->d = d; //двигаємопопередуелемент
pv->p = 0; //а новийставимо на першу позицію
(*pend)->p = pv;
*pend = pv;
}
Node* operator -(Node **pbeg)//видалитиелемент
{
int temp = (*pbeg)->d; //елементзаписуемоякийпотрібенвийти
Node *pv = *pbeg; //записуемо той який стане останнімтобто першим якийвийде
*pbeg = (*pbeg)->p;
delete pv; //видаляємоелементякийвийшов
}

bool operator()(const Och &sender)//оператор перевірки на порожністьчерги
{
Node *it1 = ft;//показчик на 1 елементоб,єкта

if(it1->d != NULL) return true;//якщоякщочерганепуста то повернення 0
return false;//якщо пуста то повернення 1
}
void Print()//вивідчерги на екран
{
Node *it = ft;//поставити на 1 елемент
while(it)//покиит правда
{
printf("%c", it->d);//виводемосимволи з черги
it = it->p;//рухаємося до наступного
}
printf("\n");//перенос строки
}
};


void main()
{
Och *pbeg;
pbeg->first(1); //створеннячерги
Och *pend = pbeg; //початок черги
for (int i = 2; i<6; i++) //
pend +(&pend, i); //додаванняелементу в чергу
while (pbeg)
printf("%d",-(&pbeg)); //видаленняелемента в з черги
_getch();
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.10.2013, 21:40
Ответы с готовыми решениями:

Где ошибки в программе? Чего не хватает?
Здравствуйте,задали задание в универе: &quot;Заданные два одномерных массива {ai} и {bi} (i=1,2...n). Сформировать два новых массива {ci} и...

Подскажите, где ошибка в программе
#include&lt;iostream.h&gt; #include&lt;math.h&gt; void main() {int b,k,t; b=0;k=0;t=0; {if ...

Подскажите кто может и найдите ошибки в программе))
#include &lt;stdio.h&gt; #include &lt;conio.h&gt; #define ROWS 3 #define COLS 3 void Changenrow(int, int , int, int; void dobaviti(int&amp;, int...

6
Заблокирован
27.10.2013, 21:43
какая ошибка то ?

Не по теме:

ты хохлушка? :D

0
 Аватар для 123456776
1 / 1 / 0
Регистрация: 09.09.2013
Сообщений: 41
27.10.2013, 21:51  [ТС]
error C2804: бинарный 'operator +' имеет слишком много параметров
1>c:\documents and settings\userxp\рабочий стол\новая папка (2)\as\as\2.cpp(57) : error C2333: Och::operator +: ошибка в объявлении функции; пропуск основного текста функции
1>c:\documents and settings\userxp\рабочий стол\новая папка (2)\as\as\2.cpp(55) : error C2440: return: невозможно преобразовать 'Och::Node *' в 'Och *'
1> Типы, на которые указывают указатели, не связаны; для преобразования требуется reinterpret_cast, приведение в стиле С или приведение в стиле функции
1>c:\documents and settings\userxp\рабочий стол\новая папка (2)\as\as\2.cpp(98) : warning C4552: +: оператор не имеет результата; требуется оператор с побочным действием
1>c:\documents and settings\userxp\рабочий стол\новая папка (2)\as\as\2.cpp(100) : error C2171: -: недопустимо для операндов типа "Och **"

Добавлено через 5 минут
а ты нацист чтоль?
0
Заблокирован
27.10.2013, 21:53
Цитата Сообщение от 123456776 Посмотреть сообщение
а ты нацист чтоль?
нет ))) С чего ты взяла? ))))
По поводу твоей программы - те ж компилятор говорит в чём ошибка. Тебе что то не ясно?
0
 Аватар для 123456776
1 / 1 / 0
Регистрация: 09.09.2013
Сообщений: 41
27.10.2013, 22:01  [ТС]
как их исправить
0
Заблокирован
27.10.2013, 22:10
Цитата Сообщение от 123456776 Посмотреть сообщение
как их исправить
Ты лучше скажи что тебе ваще сделать надо, в этом твоём куске кода всё не так
printf("%d",-(&pbeg)); - тут минус убери
Цитата Сообщение от 123456776 Посмотреть сообщение
bo
Node &operator+ (Node **pend,int pd)//оператордодаваняелементу
{
Node *pv = new Node; //показник
pv->d = d; //двигаємопопередуелемент
pv->p = 0; //а новийставимо на першу позицію
(*pend)->p = pv;
*pend = pv;
}
тут ваше надо передавать в функцию указатель на самого себя ианче как ты представляешь себе использование переопределённого оператора.... ДА много тут ошибок....
0
 Аватар для 123456776
1 / 1 / 0
Регистрация: 09.09.2013
Сообщений: 41
27.10.2013, 22:19  [ТС]
Нужно создать класс- абстрактного типа данных. Определить и реализовать операции над данными этого класса. Написать прогу для полного тестирования класса.
Класс должен быть как Очередь. В нем операции + это добавить элемент; - убрать элемент; bool() - проверка пуста ли очередь.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.10.2013, 22:19
Помогаю со студенческими работами здесь

Подскажите где ошибки..
Здраствуйте ув. знатоки! есть у меня вот код программы: #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;conio.h&gt; ...

Очень нужен совет где найти ошибки в программе
//Obrabotka rezulitatov sessii s ispolizovaniem functii #include&lt;iostream&gt; #include&lt;iomanip&gt; #include&lt;string.h&gt; #include&lt;assert.h&gt; ...

структуры подскажите где ошибки
Ребята посмотрите код Пока сделал (думал что сделал) первых 4 пункта но начинает выдавать ошибки посмотрите что за ошибки Предметная...

структуры (подскажите где ошибки)
Ребята посмотрите код я только начал делать задание но выдает ошибки что надо сделать написал ниже пробую пока только начало ...

Подскажите где в программе может быть ошибка
#include &lt;iostream&gt; #include &lt;math&gt; #include &lt;conio&gt; #include &lt;time.h&gt; #include &lt;stdio.h&gt; using namespace std; FILE *f1; ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru