close

Вход

Забыли?

вход по аккаунту

?

Описание МРЗ вариант 11

код для вставкиСкачать
Описание метода решения задач
Вариант 11.
При составлении алгоритма решения поставленной задачи необходимо применять основные принципы алгоритмизации:
1. Выявить исходные данные, результаты, назначить им имена
2. Выбрать метод решения задачи
3. Разбить метод решения задачи на этапы (с учетом возможностей ЭВМ)
4. Изобразить каждый этап в виде соответствующего блока схемы алгоритма и указать стрелками порядок их выполнения
5. В полученной схеме при любом варианте вычислений
- предусмотреть выдачу результатов или сообщения об их отсутствии
- обеспечить возможность перехода после выполнения любой операции к блоку "останов"
Выбирая метод решения задачи необходимо руководствоваться правилами описания метода решения задачи:
- выделить величины, являющиеся исходными для задачи
- разбить процесс решения задачи на этапы, которые известны исполнителю и которые он может выполнить однозначно без пояснений
- указать порядок выполнения этапов
- указать признак окончания процесса решения задачи
- указать результат решения задачи
Разбивая метод решения задачи на этапы необходимо учитывать возможности ЭВМ.
ЭВМ может:
- считывать данные с любого устройства ввода и помещать их в отведенную для них ячейку памяти, операция "Ввод"
- производить вычисления по определенным формулам, операция "Присвоить"
- сравнивать значения двух арифметических или текстовых величин, операция "Сравнить"
- переходить от одного этапа решения задачи к другому, операция "Переход"
- печатать на бумаге или выводить на экран монитора результат решения задачи, операция "Вывод"
При построении блок схемы алгоритма задачи необходимо изобразить указанные операции в виде соответствующей геометрической фигуры:
- операция "Ввод"- трапеция
- операция "Присвоить"- прямоугольник
- операция "Сравнить"- ромб
- операция "Переход"- стрелки
- операция "Вывод"- параллелограмм
и так как задачи на производные типы, то учесть суть построения циклического алгоритма:
1. Вывести три набора формул и условие окончания (повторения) цикла, в том числе:
- рабочие формулы
- законы изменения аргументов (переменных)
- формулы для вычисления начальных значения аргументов (переменных)
2. Изобразить типовую схему алгоритма и разместить в ней все указанные формулы и условие.
Задача №1. Дано натуральное число n, действительная матрица размера n*7. Найти среднее арифметическое каждого из столбцов, имеющих четные номера
Описание метода решения задачи
1. Выявляем исходные данные, результаты, назначаем им имена.
Исходные данные: квадратная матрица int mass[5][45] размерность матрицы: int N; Результаты: sr - среднее арифметическое каждого из столбцов, имеющих четные номера
s - сумма элементов четных столбцов (промежуточный результат)
2. Выбираем метод решения задачи, разбиваем на этапы (с учетом возможностей ЭВМ)
Первоначально составим укрупненную схему, а затем подробную для блоков IV, V
Укрупненная схема
I. Подключение всех необходимых заголовочных файлов
II. Глобальные описания переменных int mass[5][45],N; double s;
III. Определение размерности 2-го мерного массива IV. Элементы матрицы принимаются как случайные числа, вывод матрицы на экран в виде таблицы
V. Получение необходимого результата и вывод его на экран
IV. Вывод матрицы на экран в виде таблицы
for (int i=0; i<n; i++)
{ for (int j=0; j<n*7; j++)
{ mass[i][j]=random(20);
cout<<setw(3)<<mass[i][j];
}
cout<<endl;
}
V. 1. Так как алгоритм циклический, то выводим три набора формул и условие окончания (повторения) цикла. - рабочие формулы -s=s+ mass[i][j];
- закон изменения аргументов (переменных): i=i+1, j=j+1
- формулы для вычисления начальных значения аргументов (переменных): i:=0; j=0; s =0;
- условие повторения i<n, j<n*7
2. МРЗ:
* поиск суммы в каждом из столбцов, имеющих четные номера: цикл обработки массива: используем алгоритм расчета матрицы при работе со столбцами - цикл столбцов
операторные скобки
[блок присваивания переменным начальных значений]
цикл строк - проверяем четный столбец? if (j % 2 !=0), если Да, то считаем сумму по рабочей формуле s=s+mass[i][j];
- вывод результата: - прежде чем выводить значения типа double, необходимо указать количество знаков после точки (оператор указывается до цикла cout<<setprecision(2);)
- для проверки правильности решения задачи выводим на экран суммы четных столбцов - cout<<j+1<<"- столбец"<<setw(7)<<"s="<<s;
- и среднее арифметическое каждого из них - cout<<setw(9)<<"sr="<<s/n<<endl; Программа, реализующая данный алгоритм
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<iostream.h>
#include<iomanip.h>
int main()
{
clrscr();
randomize();
int mass[5][45],n;
double s,d[25];
printf("Размерность массива не больше 3-х n="); cin>>n;
printf("Исходный массив:\n");
for (int i=0; i<n; i++)
{
for (int j=0; j<n*7; j++)
{
mass[i][j]=random(20);
cout<<setw(3)<<mass[i][j];
}
cout<<endl;
}
printf("среднеарифметическое значение элементов четных столбцов:\n");
cout<<setprecision(2);
for (int j=0; j<n*7; j++)
{
s=0;
for (int i=0; i<n; i++)
if (j %2 !=0) s=s+mass[i][j];
if (j %2 !=0)
{
cout<<j+1<<"- столбец"<<setw(7)<<"s="<<s;
cout<<setw(9)<<"sr="<<s/n<<endl;
}
}
cout<<"\n";
getch();
}
Задача №2. В заданной строке заменить слово "дитя" на слово "ребенок". Подсчитать, на сколько удлинилась строка.
Описание метода решения задачи
1. Выявляем исходные данные, результаты, назначаем им имена.
Исходные данные: исходная строка *str1- объявляется как указатель; переменная-указатель-*tmp, в неё будем записывать начальный адрес новой строки
len1- длина исходной строки
len2- длина полученной строки
k - определяет разность исходной и полученной строк
Результаты: новая строка str2
2. Выбираем метод решения задачи, разбиваем на этапы (с учетом возможностей ЭВМ)
Первоначально составим укрупненную схему, а затем подробную для блока III.
Укрупненная схема
I. Подключение всех необходимых заголовочных файлов
II. Глобальные описания переменных char *str1,*tmp,*str2; int k=0,len1=0,len2=0;
III. Получение необходимого результата и вывод его на экран
III. 1. МРЗ:
* вводим строку (gets(str1); функция считывает строку из stdin и записывает адрес str1, добавляя символ '\0')
* в переменной tmp сохраняем начальный адрес новой строки tmp= str2;
* в переменную len1 записываем длину исходной строки - len1=strlen(str1);
* в цикле "перебора элементов строки" - while(*str1 != '\0'):
- проверяем четыре символа *str1,*(str1+1),*(str1+2) и *(str1+3), в программе это составное условие запишется следующим образом: if(*str1 == 'д' && *(str1+1)=='и' && *(str1+2)=='т'&& *(str1+3)=='я')
и, если совпадение есть, то: в новую строку *str2 записываем символ "р" - *str2='р'. Увеличиваем адрес переменной str2 на одну ячейку str2++ и в строку *str2 записываем символ "е" *str2='е', вновь увеличиваем адрес переменной str2 на одну ячейку str2++ и снова записываем символ "б" по этому адресу и так далее, пока в новую строку *str2 не будет посимвольно записано слово "ребенок"; после последнего записанного символа увеличиваем адрес переменной str2 на одну ячейку str2++ и исходную строку увеличиваем на три символа - str1+=3; иначе в новую строку переписываем символ из исходной строки - *str2=*str1; и увеличиваем адрес переменной str2 на одну ячейку str2++
- не забываем увеличивать адрес переменной str1 на одну ячейку (str1++), иначе из цикла не выйдем * после окончания цикла "перебора элементов строки str1" в новую строку записываем символ конца строки (*str2='\0';)
* в переменную len2 записываем длину новой строки - len2=strlen(str2);
* вычисляем насколько удлинилась новая строка - k=len2-len1;
* вывод результата: - предварительно нужно перейти на начало новой строки - str2=tmp;
- выводим на экран новую строку str2 и сообщение "строка удлинилась на k символов";
Программа, реализующая данный алгоритм
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <ctype.h>
void main()
{
char *str1,*tmp,*str2;
int k=0,len1=0,len2=0;
clrscr();
printf("Введи строку ....\n");
gets(str1);
len1=strlen(str1);
tmp=str2;
while(*str1 !='\0')
{
if(*str1 == 'д' && *(str1+1)=='и' && *(str1+2)=='т'&& *(str1+3)=='я')
{*str2='р';str2++;*str2='е';str2++; *str2='б';str2++; *str2='е';str2++;*str2='н';str2++;*str2='о';str2++;*str2='к';str2++;str1+=3;}
else {*str2=*str1;str2++;}
str1++;
}
*str2='\0';
str2=tmp;
len2=strlen(str2);
k=len2-len1;
printf("\n%s",str2);
printf("\nстрока удлинилась ",k); printf(" символ(ов)");
getch();
}
Задача №3. Багаж пассажира характеризуется количеством вещей и общим весом вещей. Создать список, содержащий информацию о багаже нескольких пассажиров. Вывести этот список в виде таблицы. Найти число пассажиров, имеющих более двух вещей. Если таких нет, то вывести сообщение об этом.
Документ
Категория
Рефераты
Просмотров
14
Размер файла
68 Кб
Теги
описание, вариант, мрз
1/--страниц
Пожаловаться на содержимое документа