Главная страница
Навигация по странице:

  • Теория Массив

  • define

  • Анализ задачи и алгоритм Анализ задачи Входные данные

  • Результат

  • Описание программной реализации

  • Используемые функции Для реализации построенного алгоритма на языке Си были использованы следующие стандартные функции

  • Пример работы программы Тест №1

  • лаба по Си с использованием массивов. Лаба_2. Цель Научиться решать задачи с использованием массивов. Вариант задания


    Скачать 429 Kb.
    НазваниеЦель Научиться решать задачи с использованием массивов. Вариант задания
    Анкорлаба по Си с использованием массивов
    Дата06.08.2019
    Размер429 Kb.
    Формат файлаdoc
    Имя файлаЛаба_2.doc
    ТипПрограмма
    #84814
    страница1 из 2
      1   2

    1. Цель

    Научиться решать задачи с использованием массивов.

    1. Вариант задания

    Вариант 12

    Известен день недели, который приходится на 1 января текущего года. Программа должна найти все “черные вторники” и “черные пятницы” текущего года (то есть – 13 числа).


    1. Теория

    Массивупорядоченный набор элементов, каждый из которых хранит одно значение, идентифицируемое с помощью одного или нескольких индексов. В простейшем случае массив имеет постоянную длину и хранит единицы данных одного и того же типа, а в качестве индексов выступают целые числа.

    В языке Си существуют статические массивы, число элементов в которых должно быть известно в момент компиляции программы, и динамические массивы, размер которых задается в процессе выполнения программы, то есть может зависеть от входных данных. Эти два типа отличаются только методом создания массива, в данной лабораторной работе рассматривались статические массивы.

    Способы объявления статических массивов

    Объявление статического массива отличается от объявления обычной переменной только указанием количества элементов массива. Например, следующее объявление означает, что именем points называется массив из 100 действительных чисел.

    double points[100];

    Объявление массива может быть совмещено с присвоением значений его элементам. Например,

    double points[] = {1.0, 3.14, -1.2, 12.65};

    создает массив из четырех действительных чисел с указанными значениями. В данном случае число элементов массива в квадратных скобках не указывается. Компилятор самостоятельно вычисляет длину по списку начальных значений

    Работа с элементами массива


    Для доступа к элементу массива достаточно знать его имя и порядковый номер элемента. В языке Си элементы массива индексируются начиная с нуля, то есть в массиве из двух элементов корректными являются индексы 0 и 1. Если массив имеет имя array, то его k-й элемент записывается как array[k]. Это выражение может использоваться как для получения значения элемента массива, так и для его изменения, если оно стоит в левой части оператора присваивания. Рассмотрим для примера следующую программу.

    #define NPOINTS 100

    int main() {

    double points[NPOINTS];

    int k;

    points[0] = 0.1;

    for(k=1; k < NPOINTS; k++) {

    points[k] = 0.1 + points[k-1];

    }

    return 0;

    }

    Эта программа заполняет массив действительных чисел значениями 0, 0.1, 0.2 и так далее. Отметим, что макропеременная NPOINTS используется как при объявлении массива, так и в качестве верхней границы цикла по всем его элементам. Если размер массива нужно будет изменить, то достаточно исправить одну строчку в программе (#define).

    Представление массива в памяти и адресная арифметика


    В памяти ЭВМ элементы массива записаны последовательно без пропусков. Имя массива является указателем на его начальный элемент (с индексом 0). Поскольку в массиве все элементы имеют одинаковый тип, то зная адрес начала массива (A), размер одного элемента (size) и индекс k можно вычислить адрес размещения k-ого элемента: A + k*size. Если требуется получить значение k-ого элемента массива, то достаточно выполнить одно умножение (k*size), одно сложение (A + k*size) и загрузить значение из памяти по только что вычисленному адресу. Таким образом, обращение к элементу массива очень эффективно и сложность этой операции не зависит от величины индекса k: получение (или изменение) значения нулевого элемента столь же эффективно, как и миллионного.

    Обратной стороной последовательно хранения элементов в памяти является сложность вставки нового значения с сохранением порядка следования элементов. Например, если в массив нужно добавить новое значение по индексу 0, то чтобы "освободить" место все элементы массива придется сдвинуть на одну позицию. Ясно, что сложность этой операции зависит от длины массива. Чем больше длина, тем дольше выполняется это действие.


    1. Анализ задачи и алгоритм

    1. Анализ задачи

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

    Результат: число чёрных вторников и пятниц в году.

    Метод решения: сформировав дополнительный массив, мы можем осуществить циклический перебор всех дней года и зафиксировать необходимые нам.

    Выделенные подзадачи: так как количество дней в году может варьироваться, был добавлен блок для корректировки массива под високосный год.


    1. Алгоритм решения задачи





    1. Описание программной реализации

    1. Используемые переменные


    M [12] – массив данных, содержащий информацию о количестве дней в каждом месяце;

    days – целочисленная переменная для хранения дат;

    start – целочисленная переменная, фиксирующая день недели;

    i – целочисленная переменная для счётчика месяцев в году;

    black – целочисленная переменная для фиксации чёрных вторников и пятниц;

    year - целочисленная переменная тип года.

    1. Используемые функции


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

    printf ("Input string\n") – вывод на экран;

    scanf_s ("%d", &a) – запись данных в переменную;

    if ( a > b ) {} – выполнение блока при соблюдении условия;

    for ( i=0 ; i<12 ; i++) {} – циклическое выполнение блока, пока соблюдается заданное условие, с последующим изменением счётчика.


    1. Пример работы программы

    Тест №1

    Введены параметры текущего года:


      1   2


    написать администратору сайта