Основы работы со структурами в языке программирование С++
Разработка приложение в С++, содержащего различные структуры и выполняющее самого различного вида операции над ними. Создание четырех видов структур, которые характеризуют дату (время), свойства треугольника, свойства прямой и свойства комплексных чисел.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | курсовая работа |
Язык | русский |
Дата добавления | 22.06.2014 |
Размер файла | 956,6 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Введение
В данной курсовой работе предусматривается исследовать современные теоретические основы работы со структурами в языке С++. Структуры - это, своего рода сгруппированные данные, выражающие один объект. Структура может содержать сколько угодно и какие угодно типы данных. Они могут быть самыми различными, и вполне совместимы в пределах одной структуры. Например, если взять пример из математики, каждая точка может характеризоваться двумя признаками: расположением по оси х и расположением по оси у. В этом случае мы можем назвать точку структурой, состоящей из двух переменных (значений), вещественного типа, которые характеризуют координаты расположения точки на плоскости. В таких случаях, где один объект состоит из множества других объектов или имеет очень большую перечень свойств, их можно сгруппировать как одну структуру и применять их в ходе программы без никаких заблуждений и путаниц. Это облегчает работу программисту, который не располагает большим количеством времени, чтобы при выполнении какого-либо проекта он подетально вникал в подробности каждого объекта. В целях лучшего изучения способов создания, применения структур и выполнения различных операций над ними, предусмотрено разработать программу, содержащую несколько структур и операций над ними, потому что на практике научиться проще чем просто прочитать теорию. В нашем случае, теория будет закрепляться дальнейшей реализацией прочитанного и наглядно будет понятен принцип работы со структурами в языке С++.
Глава 1. Работа со структурами в среде Borland C++ Builder
1.1 Структуры в С++
Структурой называется совокупность логически связанных переменных различных типов, сгруппированных под одним именем для удобства дальнейшей обработки. Структура - это способ связать воедино данные разных типов и создать пользовательский тип данных. Структуры в С++ используются для логического и физического объединения данных произвольных типов, так же как массивы служат для группирования данных одного типа.
В общем случае при работе со структурами следует выделить четыре момента:
- объявление и определение типа структуры,
- объявление структурной переменной,
- инициализация структурной переменной,
- использование структурной переменной.
Структура в С++ задаётся следующим образом:
1:
2:
3: structdirection {
члены (элементы) структуры
};
voidmain()
{
TPoint O; //Объявили переменную O типа TPoint
}
Так описывается структура в коде программы. Стоит обратить внимание, что при объявлении структуры нет круглых скобок
structTPoint () //НЕВЕРНО
а после закрывающейся фигурной скобки стоит точка с запятой.
Объявление структуры всегда должно начинаться с ключевого слова struct. Необязательно, чтобы структура имела имя, но тогда такая структура обязательно должна иметь структурные переменные, объявленные между закрывающей фигурной скобкой и точкой с запятой. Обязательно в объявлении структуры должны присутствовать фигурные скобочки, они обрамляют тело структуры, в котором объявляются её атрибуты (элементы). Структурные переменные, при объявлении структуры, указывать необязательно.
Структурная переменная может быть задана уникальным образом:
struct //Определение анонимного типа структуры
{
char name[20];
charf_name[40];
chars_name[20];
} copymy; //Создание структурной переменной
1.2 Обращение к структуре
#include <conio.h>
#include <iostream.h>
structTPoint //Объявили новую структуру TPoint.
{
int x; //Первый параметр
int y; //Второй параметр
}; //После описания структуры ставят точку с запятой
voidmain()
{
clrscr();
TPoint O; //Объявили переменную O типа TPoint
O.x=30; //Присвоили первому параметру значение
O.y=100;//Присвоили второму параметру значение
getch();
}
В этом коде была объявлена переменная Oтип данных которой соответствует структуре TPoint
У структуры TPoint было объявлено 2 параметра. (x,y). При обращении к O программист должен обратиться к определенному параметру из структуры к которой Оотносится.
Чтобы создать вторую переменную с двумя параметрами, но отличающуюся от первой достаточно прописать
TPointO,А; //Объявили переменные O и A типа TPoint
TPointO,А; //Объявили переменные O и A типа TPoint
Код С++ структуры
#include <conio.h>
#include <iostream.h>
structTPoint //Объявили новую структуру TPoint.
{
int x; //Первый параметр
int y; //Второй параметр
}; //После описания структуры ставят точку с запятой
voidmain()
{
clrscr();
TPoint O, A; //Объявили переменные типа TPoint
O.x=30; //Присвоили первому параметру значение
O.y=100;//Присвоили второму параметру значение
A.x=130; //Присвоили первому параметру значение
A.y=10;//Присвоили второму параметру значение
getch();
}
Теперь в памяти хранятся 2 сгруппированные переменные типа TPoint. Каждой переменной соответствует по 2 параметра типа int
Теперь с элементами A.x,A.y,O.x,O.y можно работать как с обычными переменными int. Просто в примере был показан способ создания своего типа данных, в котором в одной переменной сгруппировано две. (В переменной O - две переменных типа int и в переменной Адве переменных типа int)
Данные, которые хранятся в одной структуре могут быть присвоены другой структуре если обе структуры хранят одинаковые параметры.
Можно сказать, что в предыдущей программе было объявлено две структуры Структура А и структура О.
Код С++ структуры
#include <conio.h>
#include <iostream.h>
structTPoint //Объявили новую структуру TPoint.
{
int x; //Первый параметр
int y; //Второй параметр
}; //После описания структуры ставят точку с запятой
voidmain()
{
clrscr();
TPoint O, A; //Объявили переменные типа TPoint
O.x=30; //Присвоили первому параметру значение
O.y=100;//Присвоили второму параметру значение
A=O; //теперь A.x=O.x=30, A.y=O.y=100;
//Выводим на экран структуры О и А
cout<<A.x<<endl;
cout<<A.y<<endl;
cout<<O.x<<endl;
cout<<O.y<<endl;
getch();
}
Элементы списка объявлений называются членами структуры или полями. Каждый элемент списка имеет уникальное для данного структурного типа имя. Однако следует заметить, что одни и те же имена полей могут быть использованы в различных структурных типах.
Работа со структурной переменной обычно сводится к работе с отдельными полями структуры. Доступ к членам структуры осуществляется посредством оператора . (точка):
1:
2:
3: direction.x = 0;
direction.y = 0;
direction.z = 1;
при этом обращение к полю структуры представляет собой переменную того же типа, что и поле, и может применяться везде, где допустимо использование переменных такого типа.
Под структурную переменную выделяется область памяти не менее суммы длин всех полей структуры,например,
struct list
{
char name[20];
charfirst_name[40];
int;
}L;
В данном примере объявляется тип структура с именем list, состоящая из трех полей, и переменная с именем L типа structlist,при этом для переменной L выделяется 64 байта памяти.
1.3 Использование структур
Структуры в С++ используются для логической или физической группировки объектов, имеющих общий контекст. Использование структур при написании собственных типов данных рекомендуется в том случае, если выполняется ряд условий:
* Создаваемый тип данных не имеет собственного поведения. То есть объект такого типа рассматривается как пассивный набор данных.
* Члены данных создаваемого типа данных не могут находиться во взаимно противоречивом состоянии. То есть любая комбинация значений членов структуры является допустимой.
Для более сложных пользовательских типов данных в языке С++ используются классы.
Структуры позволяют достаточно эффективно решить вопрос возврата множества значений из функции. Если функция должна вернуть несколько значений в качестве результата, то их достаточно поместить в структуру и возвращать значение указанного типа.
В качестве типов членов структуры могут использоваться ранее объявленные пользовательские типы.
Над структурами возможны следующие операции:
- присваивание значений одной структурной переменной другой структурной переменной, при этом обе переменные должны иметь один и тот же тип;
- получение адреса переменной с помощью операции &;
- осуществление доступа к членам структуры.
Присваивание значения одной переменной другой выполняется путем копирования значений соответствующих полей, например:
struct point pt={105,15},pt1;
pt1=pt;
В результате выполнения этого присваивания в pt1.x будет записано значение 105, а в pt1.y - число 15.
Объекты структур можно присваивать, передавать в качестве аргументов и возвращать в качестве значений функций. Другие операторы (такие как == и != не определены).
Существует три способа передачи структур функциям:
- передача компонентов структуры по частям;
- передача целиком структуры;
- передача указателя на структуру.
voidshowrect(struct point p1,struct point p2)
{
printf("Левый верхний угол прямоугольника:%d %d\n",
p1.x, p1.y);
printf("Правый нижний угол прямоугольника:
%d %d\n", p2.x, p2.y);
}
При вызове такой функции ей надо передать две структуры:
struct point pt1={5,5},
pt2={50,50};
showrect(pt1,pt2);
Функция, возвращающая структуру:
structpointmakepoint (intx,inty) /*makepoint - формирует точку по компонентам x и y*/
{
struct point temp;
temp.x = x;
temp.y = y;
return temp;
}
Результат работы этой функции может быть сохранен в специальной переменной и выведен на экран:
struct point buf;
buf=makepoint(10,40);
printf("%d %d\n",buf.x,buf.y);
После выполнения этого фрагмента на экран будут выведены два числа: 10 и 40.
Структуры нельзя сравнивать. Сравнивать можно только значения конкретных полей.
Объекты структур могут являться элементами массивов.
1.4 Указатели на структуру
Если функции передается большая структура, то эффективнее передать указатель на эту структуру, нежели копировать ее в стек целиком. Указатель на структуру по виду ничем не отличается от указателей на обычные переменные.
Формат: structpoint *pp;
Где pp - указатель на структуру типа structpoint, *pp - сама структура, (*pp).x и (*pp).y - члены структуры.
Скобки (*pp).x необходимы, так как приоритет операции (.) выше приоритета операции (*). В случае отсутствия скобок *pp.x понимается как *(pp.x).
Инициализация указателя на структуру выполняется так же, как и инициализация указателей других типов: structpointvar1, *S1;
здесьvar1 - структурная переменная, *S1 - указатель на структуру.
Для определения значения указателя ему нужно присвоить адрес уже сформированной структуры: S1 = &var1;
Теперь возможно еще одно обращение к элементам структуры: (*S1).name.
Указатели на структуры используются весьма часто, поэтому для доступа к ее полям была введена короткая форма записи. Если р - указатель на структуру, то p > <поле структуры>зволяет обратиться к указанному полю структурной переменной.
Знак > (стрелка) вводится с клавиатуры с помощью двух символов: '-' (минус) и '>' (больше). Например, pp > x; pp > y.
Операторы доступа к полям структуры (.) и (>) вместе с операторами вызова функции () и индексами массива [] занимают самое высокое положение в иерархии приоритетов операций в языке C.
Указатели на структуру используются в следующих случаях:
* доступ к структурам, размещенным в динамической памяти;
* создание сложных структур данных - списков, деревьев;
* передача структур в качестве параметров в функции
1.5 Вложенные структуры
Полем структурной переменной может быть переменная любого типа, в том числе другая структурная переменная. Поле, представляющее собой структуру, называется вложенной структурой.
Тип вложенной структуры должен быть объявлен раньше. Кроме того, структура не может быть вложена в структуру того же типа.
Объявление вложенной структуры:
structpoint
{
intx,y;
};
structrect
{
struct point LUPoint, RDPoint;
charBorderColor[20];
};
structrectRect;
В переменной Rectдва поля LUPoint (точка, соответствующая левому верхнему углу прямоугольника) и RDPoint (точка, соответствующая правому нижнему углу) представляют собой вложенные структуры. Для доступа к полю вложенной структуры следует сначала обратится к внешней структуре, затем к вложенной: Rect.LUPoint.x.
Пример создания и использования вложенной структуры:
structrectRect={10,5,50,25,"White"};
printf("Параметры прямоугольника:\n");
printf("Координаты левого верхнего угла %d %d\n", Rect.LUPoint.x, Rect.LUPoint.y);
printf("Координаты левого верхнего угла %d %d\n", Rect.RDPoint.x, Rect.RDPoint.y);
printf("Цветграницы: %s\n", Rect.BorderColor);
В качестве поля структуры также можно использовать указатели на любые структуры, в том числе на структуры того же типа:
structPointList
{
intx,y;
structPointList* LastPoint;
};
Структуры, имеющие в своем составе поля-указатели на такую же структуру, используются для создания сложных структур данных - списков, деревьев.
1.6 Использование синонима типа
Ключевое слово typedefпозволяет в программе создать синоним типа, который может использоваться для объявления переменных, параметров функций. Синоним можно создать для любого существующего типа (int, floatи т. д.), в том числе для пользовательского типа - структуры или массива.
Пример 1. Создание синонима структуры:
typedefstructpoint
{
intx,y;
} POINT;
Идентификатор POINT представляет собой синоним типа point. С помощью синонима POINT можно объявить переменную: POINTpt1;
или передать переменную в функцию:
voidShowRect(POINT pt1,POINT pt2);
Пример 2. Создание синонима массива:
typedeffloatmas[4][5];
Идентификатор mas обозначает тип - двумерный массив, состоящий из четырех строк и пяти столбцов. Этот идентификатор можно использовать для объявления переменной - массива A:
masA;
или для передачи массива в функцию:
voidFormMas(mas A,intm,int n);
1.7 Типичные ошибки при разработке структур
Наиболее часто встречающейся ошибкой является включение в структуру взаимозависимых данных. То есть таких членов, значения которых могут быть вычислены на основании других членов структуры.
Например, неправильной структурой будет:
1:
2:
3:
4: structLine {
pt1,pt2;
double length;
};
В данном случае член length может быть вычислен на основании pt1 и pt2. Хранение значение length в структуре нарушает вторую рекомендацию по использованию структур. Кроме расхода памяти для хранения избыточной информации программист получает намного более сложную проблему: необходимость синхронизации данных. При каждом изменении любого из членов структуры придётся пересчитывать значение length.
Более утончённые примеры ошибок:
1:
2:
3: // Прямоугольник на плоскости
struct Box2 {
vec2pt1, pt2, pt3, pt4;
};
1:
2:
3:
4:
5: // Окружность в трехмерном пространстве
struct CircleIn3D {
Plane plane; // Плоскость, в которой лежит окружность
vec3 center;
doubleradius;
};
Глава 2. Разработка приложений с использованием структур в С++
Была разработана единая программа, которая включает в себя несколько операций над различными структурами, которые были созданы нами же. Она имеет вид формы, на которой расположены четыре панели, каждая панель группирует задачи, относящиеся к одной и той же структуре. Например, на первой панели размещены поля для ввода даты и окно для вывода описания человека по дате рождения.
Вычисляется это следующим образом:
dt1.day = StrToInt(LabeledEdit1->Text);
dt1.month = StrToInt(LabeledEdit2->Text);
dt1.year = StrToInt(LabeledEdit3->Text);
dt1.century = dt1.year/100+1;
dt1.decade = 10*(dt1.year/10-10*(dt1.century-1));
if ((dt1.month < 3)||(dt1.month == 12)) {
dt1.season = "зима";
}
else if (dt1.month < 6) {
dt1.season = "весна";
}
else if (dt1.month < 6) {
dt1.season = "лето";
}
else dt1.season = "осень";
Memo1->Lines->Add("Этотчеловекродилсяв "+IntToStr(dt1.decade)+
"- годах "+IntToStr(dt1.century)+"-века. Время года - "+dt1.season);
На второй панели можно увидеть поля для ввода сторон треугольника, поле для вывода ответа и три кнопки для каждого вычисления отдельно.
(вычисления площади, типа и угла треугольника).
tr.a = StrToFloat(LabeledEdit4->Text);
tr.b = StrToFloat(LabeledEdit5->Text);
tr.c = StrToFloat(LabeledEdit6->Text);
float p = (tr.a+tr.b+tr.c)/2;
float area = sqrt(p*(p-tr.a)*(p-tr.b)*(p-tr.c));
Memo2->Lines->Add("площадь = "+FloatToStr(area));
tr.a = StrToFloat(LabeledEdit4->Text);
tr.b = StrToFloat(LabeledEdit5->Text);
tr.c = StrToFloat(LabeledEdit6->Text);
float max = tr.a;
floatsmt = tr.b*tr.b+tr.c*tr.c;
if (tr.b>max) {
max = tr.b;
smt = tr.a*tr.a+tr.c*tr.c;
}
if (tr.c>max) {
max = tr.c;
smt = tr.b*tr.b+tr.a*tr.a;
}
if (max*max-smt> 0) {
Memo2->Lines->Add("тупоугольный");
}
else if (max*max-smt == 0) {
Memo2->Lines->Add("прямоугольный");
}
else Memo2->Lines->Add("остроугольный");
tr.a = StrToFloat(LabeledEdit4->Text);
tr.b = StrToFloat(LabeledEdit5->Text);
tr.c = StrToFloat(LabeledEdit6->Text);
float max = tr.a;
floatsmt = tr.b*tr.b+tr.c*tr.c;
floatsmot = 2*tr.b*tr.c;
if (tr.b>max) {
max = tr.b;
smt = tr.a*tr.a+tr.c*tr.c;
smot = 2*tr.a*tr.c;
}
if (tr.c>max) {
max = tr.c;
smt = tr.b*tr.b+tr.a*tr.a;
smot = 2*tr.b*tr.a;
}
float angle = acos((smt - max*max)/smot);
Memo2->Lines->Add("Наибольшийугол"+FloatToStr(angle));
На третьей панели размещены поля ввода координат прямой, поле для вывода результатов и на трех кнопках выводится уравнение прямой, вычисляется угол наклона и пересечение двух прямых.
ln.x1 = StrToFloat(LabeledEdit7->Text);
ln.y1 = StrToFloat(LabeledEdit8->Text);
ln.x2 = StrToFloat(LabeledEdit9->Text);
ln.y2 = StrToFloat(LabeledEdit13->Text);
float k = (ln.y2-ln.y1)/(ln.x2-ln.x1);
float b = ln.y1-k*ln.x1;
Memo3->Lines->Add("y = "+FloatToStr(k)+"x + "+FloatToStr(b));
ln.x1 = StrToFloat(LabeledEdit7->Text);
ln.y1 = StrToFloat(LabeledEdit8->Text);
ln.x2 = StrToFloat(LabeledEdit9->Text);
ln.y2 = StrToFloat(LabeledEdit13->Text);
float k = (ln.y2-ln.y1)/(ln.x2-ln.x1);
Memo3->Lines->Add("уголнаклона- "+FloatToStr(atan(k))+" градусов");
ln.x1 = StrToFloat(LabeledEdit7->Text);
ln.y1 = StrToFloat(LabeledEdit8->Text);
ln.x2 = StrToFloat(LabeledEdit9->Text);
ln.y2 = StrToFloat(LabeledEdit13->Text);
float k = (ln.y2-ln.y1)/(ln.x2-ln.x1);
float b = ln.y1-k*ln.x1;
float c = -b/k;
Memo3->Lines->Add("пересечениесосью x: "+FloatToStr(c));
Memo3->Lines->Add("пересечениесосью y: "+FloatToStr(b));
На четвертой панели вводятся комплексные числа и выполняются вычисления по заданной формуле, вычисление модуля и вычисления сопряжения комплексного числа.
a.x = StrToFloat(LabeledEdit10->Text);
a.y = StrToFloat(LabeledEdit11->Text);
b.x = StrToFloat(LabeledEdit12->Text);
b.y = StrToFloat(LabeledEdit14->Text);
mult(b,b,e);
sum(a,b,d);
sum(e,d,b);
sum(a,b,e);
Memo4->Lines->Add("a+b^2+(a+b) = "+FloatToStr(e.x)+" + "
+FloatToStr(e.y)+"i");
a.x = StrToFloat(LabeledEdit10->Text);
a.y = StrToFloat(LabeledEdit11->Text);
b.x = StrToFloat(LabeledEdit12->Text);
b.y = StrToFloat(LabeledEdit14->Text);
float ma = sqrt(a.x*a.x + a.y*a.y);
floatmb = sqrt(b.x*b.x + b.y*b.y);
Memo4->Lines->Add("|a| = "+FloatToStr(ma));
Memo4->Lines->Add("|b| = "+FloatToStr(mb));
a.x = StrToFloat(LabeledEdit10->Text);
a.y = StrToFloat(LabeledEdit11->Text);
b.x = StrToFloat(LabeledEdit12->Text);
b.y = StrToFloat(LabeledEdit14->Text);
e.x = a.x; e.y = -a.y;
d.x = b.x; d.y = - b.y;
Memo4->Lines->Add("число, сопряженноеa: "+FloatToStr(e.x)+
"+"+FloatToStr(e.y)+"i");
Memo4->Lines->Add("число, сопряженное b: "+
FloatToStr(d.x)+"+"+FloatToStr(d.y)+"i");
Для того, чтобы программа понимала откуда такие объекты, ранее были объявлены соответствующие структуры следующего вида:
struct Date {// структурадата
int day;
int month;
int year;
int decade;
String season;
int century;
} dt1; // объявление переменной этой структуры
structTriangle { // структура Треугольник
float a;
float b;
float c;
} tr; // объявление переменной этой структуры
structLine { // структура для прямой линии
float x1;
float y1;
float x2;
float y2;
} ln; // объявление переменной этой структуры
structComplex { // структура для комплексных чисел
float x;
float y;
} a,b,e,d; // объявление переменных этой структуры
Заключение
программирование структура приложение
В целях подробного просмотра возможностей работы со структурами в С++ было разработано приложение содержащее различные структуры и выполняющее самого различного вида операции над ними. В ходе разработки программы, было создано четыре вида структур, которые характеризуют дату (время), свойства треугольника, свойства прямой и свойства комплексных чисел. С помощью различных задач, были приведены различные способы работы со структурами. Так как, структуры это «мини» классы, они очень схожи в объявлении и имеют схожие свойства. Структура тоже, отчасти, новый тип данных, но в узком смысле этого слова. У нас структуры содержат различного рода информацию и свойства одного определенного понятия. Структуру можно один раз описать и с помощью разных объявленных переменных использовать как несколько структур с одинаковыми свойствами. Мы воспользовались этим свойством структур и выполнили несколько операций над такими структурами, отличающимися друг от друга лишь названием (две прямых xи у, два комплексных числа а и b).
Как видите, это очень удобно в выполнении многочисленных вычислений с данными, имеющими несколько одинаковых или схожих свойств. Используя структуры, необязательно перед каждым новым объектом описывать его свойства в ряд, достаточно по определенным критериям сгруппировать данные и в начале программы оформить их в виде структур и в дальнейшем использовать их сколько угодно раз, с разным обозначением.
Использованная литература
· Громов Ю. «Программирование на языке C»
· Вальпа О. «Borland C++ Builder»
· Златопольский Д.М. «Сборник задач по программированию»
· Прата С. «Язык программирования С++»
· Культин Н. Б. «Основы программирования в Delphi 7»
· «Borland C++ Builder. Освой самостоятельно за 21 день»
· Дейтел Х., Дейтел П «Как программировать на C++»
· Крупник А.Б. «Изучаем C++»
· Архангельский, «С++ Справочное пособие»
· «Объектно-ориентированное программирование в C++»
· Липпман С., Лажойе Ж. «Язык программирования C++»
· Страуструп Б. «Язык программирования C++»
· Павловская Т.А., Щупак Ю.А. «С и С++ Структурное программирование»
Размещено на Allbest.ru
Подобные документы
Функционирование разрабатываемого элемента управления ActiveX, его свойства и методы. Создание внешнего вида элемента управления. Программирование событий инициализации и изменения размеров. Тестирование элемента на этапе проектирования и выполнения.
курсовая работа [1,4 M], добавлен 07.04.2014Написание программы для генерации случайных чисел, в которой реализуются возможности генерации абсолютно случайных чисел. Приложение на языке С/С++. Описание узла, содержащего данные; функций и методов работы; чтения данных из памяти и вывода их на экран.
курсовая работа [172,4 K], добавлен 23.05.2012Особенности строковых типов данных и их обработка. Записи как совокупность поименованных компонентов различных типов, основные принципы работы с ними. Массивы - элементы и массивы структур. Понятие и свойства объединений. Файлы и работа с ними в языке СИ.
презентация [73,1 K], добавлен 09.12.2013Создание приложения для Android на языке Java. Переключатель языка и варианты перевода, которые появляются, когда пользователь вводит текст в поле. Возможность просмотра истории переводов. Разработка и подготовка вида экранов тестового приложения.
курсовая работа [114,8 K], добавлен 03.08.2017Понятие алгоритма, его свойства. Дискретность, определенность, результативность, формальность как свойства алгоритма. Программа как описание структуры алгоритма на языке алгоритмического программирования. Основные структурные алгоритмические конструкции.
реферат [1,3 M], добавлен 18.11.2010Целые числа в позиционных системах счисления. Недостатки двоичной системы. Разработка алгоритмов, структур данных. Программная реализация алгоритмов перевода в различные системы счисления на языке программирования С. Тестирование программного обеспечения.
курсовая работа [593,3 K], добавлен 03.01.2015Система счисления как совокупность приемов и правил для обозначения и наименования чисел, ее разновидности и критерии классификации. Свойства позиционных однородных систем с естественным множеством цифр. Преобразование чисел из одной системы в другую.
методичка [1,3 M], добавлен 21.09.2011Процедура обработки события. Просмотр и изменение значений свойств формы и ее компонентов. Значение свойств height. Раскрытый список вложенных свойств сложного свойства BorderIcons. Приложение, вычисляющее площадь треугольника. Внешний вид приложения.
контрольная работа [215,4 K], добавлен 11.06.2009Расчет матрицы по заданной формуле. Формирование вектора по алгоритму, построение его вектора. Структура окна С++. Свойства события компонент С++, которые использовались для реализации задачи. Структуры программирования. Блок-схемы алгоритмов подпрограмм.
курсовая работа [602,7 K], добавлен 26.06.2016Создание приложения и освоение начала технологии графического программирования. Использование CASE-структур в создаваемых приложениях и применение циклов типа For-Do. Создание программы, которая будет подсчитывать время выполнения определенного цикла.
курсовая работа [321,4 K], добавлен 24.06.2013