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

ООП - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Тема матрица вероятности http://www.cyberforum.ru/cpp-beginners/thread338152.html
Помогите создать 1620 на 6 матрицу, из числового интервала Просьба выложить портянку вариант такой матрицы. Сам не владею навыками написания программного кода и матанализа.
C++ Помогите разобраться с GetActiveWindows Приложение вызывает из DLL функцию, которая должна получить дескриптор главного окна этого приложения. Пытаюсь получить дескриптор функцией GetActiveWindow. Пока приложение активно (в фокусе) все работает нормально, как только приложение не активно, то GetActiveWindow возвращает NULL. В чем может быть дело? http://www.cyberforum.ru/cpp-beginners/thread338141.html
C++ Необходимо сделать проверку на отсутствие цифр и повторений букв в массиве
Пожалуйста прошу вашей помощи необходимо сделать проверку чтобы не было цифр в массиве и повторение букв, написал так: int count1=0; for (int i=0;s1!='\0';i++) { for (int j=0;s1!='\0';j++) { if(i!=j) { if(s1==s1||(!isdigit(s1))) {
C++ Физический движок
Драсти У меня вопрос к программистам,как правильно реализовать простенький физический движок то есть тот который будет просчитывать свойства тела по введеным в него данным: 1.скорость тела 2.масса 3.сила тяжести(делается так чтобы можно было делать расчёты в разных среда(космос и т.п.)) 4.плотность среды в которой находецо тело(в воде,воздухе и т.п.) Потом остальные пункты будут...
C++ Не удаётся создать безымянный объект типа vector моего типа http://www.cyberforum.ru/cpp-beginners/thread338126.html
Собсно #include <vector> using namespace std; //Вот мой австорский тип struct kletka { int i, j; kletka(int x, int y):i(x), j(y) {};
C++ Передача двумерного массива в функцию Даны две квадратные матрицы nxn. Напечатать ту из них, которая имеет минимальный “след” (т.е. сумму элементов главной диагонали). При решении создать функцию для нахождения следа матрицы и функцию печати матрицы. float Sled(float *massiv1, int number1, float *massiv2, int number2) { float s1=0,s2=0,min; int i,j; for(i=0;i<number1;i++) подробнее

Показать сообщение отдельно
fasked
Эксперт C++
 Аватар для fasked
4925 / 2505 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
02.08.2011, 02:18     ООП
Цитата Сообщение от Roof Посмотреть сообщение
поясните подробно, если не затруднит.
Я сейчас приведу несколько цитат из статьи, которые бросились мне в глаза и показались совершенно некомпетентными.

Страница первая.
Начнем с того, что автор предлагает использовать следующую структуру для узла списка. Стоит уточнить, что в статье "узел" автор называет "звеном", мне привычнее говорить и писать "узел", поэтому я буду и дальше так говорить, но стоило упомянуть об этом, чтобы не возникало недопониманий.
C++
1
2
3
4
5
struct node
    {
      int elem; //Информационный элемент звена списка 
      node *sled; // Указатель на следующее звено списка 
    };
Бросается в глаза использование транслита - этого я никогда не одобрял, да и не буду, неправильно использовать такие имена. Правда, справедливости ради, на следующей странице автор исправился. Еще может использование модификатора доступа public для данных не совсем правильно, но тут нужен контекст, в отрыве от него сложно сказать. Все это можно списать на то, что читатель скорее всего имеет уровень начинающего, да пусть будет так.

Следующий абзац на этой же странице гласит: "Чтобы иметь возможность оперировать со списком как с единым объектом, введем в употребление статическую ссылочную переменную phead, которая указывает на первое звено списка..."
Ключевое слово здесь - статическую. То есть получается, что пользователь не сможет создать несколько списков, так как переменная (указатель на голову списка) статическая. Это ужасно. Однако, сам код, который продемонстрировал автор, не содержит ни ключевого слова static, и указания на то, что объект объявлен в глобальном пространстве имен.

Страница вторая
На этом шаге мы рассмотрим построение списка без заглавного звена.
Что значит без заглавного звена? Как вообще можно манипулировать списком без указателя на его начало? Это осталось для меня тайной, так как в следующем же примере, автор использует указатель на голову списка. Может быть я неправильно понимаю слово "заглавный".
Дальше эту страницу я уже не читал. Так как текст попахивал полной ахинеей.

Страница третья.
Построение списка с заглавным звеном.
Увидел, что автор ссылается на Д. Кнута - посмеялся. Далее мой взгляд упал на код.
C++
1
2
(*t).sled = NULL;
(*t).sled = new (node);
И в том же духе. Нахрена, спрашивается, разыменовывать указатель. Автор не знает, что существует оператор доступа -> ?
C++
1
t->sled = NULL;
В первой части описывается алгоритм добавления элемента, насколько я понял. Стошнило меня, однако, на этом моменте.
C++
1
void POSTROENIE (node **phead)
После прочтенного, я позволю себе сделать выводы и небольшую аннотацию.
Может быть, автор вполне представляет себе, что такое списки. Он даже нарисовал довольно много картинок, что подверждает это предположение. Однако, объяснено все слишком грубо. Автор искрит терминологией собственного производства, которая многим может быть непонятна или введет новичков в заблуждение.
Относительно программирования вообще беда. На первой же странице читателю сообщается, что код будет написан на C++, однако, из C++ кода я заметил только использование new для выделения памяти. Автор пишет в стиле Си. Нет ни классов, ни методов, ни инкапсуляции.
При реализации списка, сам список не был представлен как отдельная сущность. Автор оперирует узлами списка, как беспорядочными объектами.
Автор не следует стандартам языка, то есть он объявляет функцию main с типом void. Кстати, вся выделенная память не освобождается.
Можно даже предположить, что автор пересел с какого-нибудь бэйсика или паскаля. Обучался программированию в шараге на динозавре Borland C++ 3.1 или чем-то подобном. А потом заимев ЧСВ более 9000 бросился писать статейки о программировании. Противоречит сам себе во многих местах.

Вердикт: не читать, ни в коем случае!
 
Текущее время: 06:52. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru