Лекция 5. Структуры


Cтруктуры — это составной объект, в который входят элементы любых типов, за исключением функций. В отличие от массива, который является однородным объектом, структура может быть неоднородной. Тип структуры определяется записью вида:

struct { список определений }

В структуре обязательно должен быть указан хотя бы один компонент. Определение структур имеет следующий вид:

тип-данных идентификаторы;

где тип-данных указывает тип структуры для объектов, определяемых в описателях. В простейшей форме описатели представляют собой идентификаторы или массивы.

Пример:

struct { double x,y; } s1, s2, sm[9];

struct { int year;

char month, day; } date1, date2;

Переменные s1, s2 определяются как структуры, каждая из которых состоит из двух компонент х и у. Переменная sm определяется как массив из девяти структур. Каждая из двух переменных date1, date2 состоит из трех компонентов year, moth, day. >p>Существует и другой способ ассоциирования имени с типом структуры, он основан на использовании тега структуры. Тег структуры аналогичен тегу перечислимого типа. Тег структуры определяется следующим образом:

struct тег { список описаний; };

где тег является идентификатором.

В приведенном ниже примере идентификатор student описывается как тег структуры:

struct student { char name[25];

int id, age;

char prp; };

или

student { char name[25];

int id, age;

char prp; };

Тег структуры используется для последующего объявления структур данного вида в форме:

struct тег список-идентификаторов;

Пример:

struct studeut st1,st2;

Использование тегов структуры необходимо для описания рекурсивных структур. Ниже рассматривается использование рекурсивных тегов структуры.

struct node { int data;

struct node * next; } st1_node;

Тег структуры node действительно является рекурсивным, так как он используется в своем собственном описании, т.е. в формализации указателя next. Структуры не могут быть прямо рекурсивными, т.е. структура node не может содержать компоненту, являющуюся структурой node, но любая структура может иметь компоненту, являющуюся указателем на свой тип, как и сделано в приведенном примере.

Доступ к компонентам структуры осуществляется с помощью указания имени структуры и следующего через точку имени выделенного компонента, например:

st1.name="Иванов";

st2.id=st1.id;

st1_node.data=st1.age;

Пример: Распределение стипендии

#include <stdio.h>

int main(int argc, char* argv[])

{

const N=3; //Count students

struct stud

{

char name[15];

char group[10];

unsigned char CountEx; //Count examins

unsigned char ball[4];

float grant;

};

/*struct*/ stud s[N];

int i, j;

unsigned char ce;

printf("Enter quantity of examinations into sessions ");

scanf("%d", &ce);

for (i=0; i<N; i++)

{

printf("Enter a name of of %d-st student ", i+1);

scanf("%s", s[i].name);

printf("Enter its group ");

scanf("%s", s[i].group);

s[i].CountEx=ce;

for (j=0; j<ce; j++)

{

printf("Enter its ball for %d-st examination ", j+1);

scanf("%d", &s[i].ball[j]);

}

}

float BaseGrant;

printf("Enter base grant ");

scanf("%f", &BaseGrant);

for (i=0; i<N; i++)

{

int isThree=0, sum=0;

for (j=0; j<s[i].CountEx; j++)

{

if (s[i].ball[j]<4)

{

isThree=1;

break;

}

sum+=s[i].ball[j];

}

if (isThree) s[i].grant=0;

else if (sum/s[i].CountEx==5) s[i].grant=BaseGrant*1.25;

else s[i].grant=BaseGrant;

printf("%2d. %-16s%7.2f\n", i+1, s[i].name, s[i].grant);

}

getchar();getchar();

return 0;

}



Дата добавления: 2016-07-27; просмотров: 1636;


Поиск по сайту:

Воспользовавшись поиском можно найти нужную информацию на сайте.

Поделитесь с друзьями:

Считаете данную информацию полезной, тогда расскажите друзьям в соц. сетях.
Poznayka.org - Познайка.Орг - 2016-2024 год. Материал предоставляется для ознакомительных и учебных целей.
Генерация страницы за: 0.009 сек.