H24 (Все лабы по инфе за 2ой сем на С++)
Описание файла
Файл "H24" внутри архива находится в следующих папках: Все лабы по инфе за 2ой сем на С++, Инфа - бесценно, homework. Документ из архива "Все лабы по инфе за 2ой сем на С++", который расположен в категории "". Всё это находится в предмете "информатика" из 2 семестр, которые можно найти в файловом архиве МГТУ им. Н.Э.Баумана. Не смотря на прямую связь этого архива с МГТУ им. Н.Э.Баумана, его также можно найти и в других разделах. Архив можно найти в разделе "лабораторные работы", в предмете "информатика" в общих файлах.
Онлайн просмотр документа "H24"
Текст из документа "H24"
Техническое задание
Введение
Разработать программу, которая для указанной даты года определяет ее соответствие названию одного из следующих 12-ти знаков зодиака: aries (овен), tautus (телец), gemini (близнецы), cancer (рак), leo (лев), vigro (дева), libra (весы), scorpio (скорпион), sagitarius (стрелец), capricon (козерог), aquarius (водолей), pisces (рыбы). При этом нужно учитывать, что для указанных знаков зодиака приняты следующие диапазоны дат года: водолей, от 21.01 до 19.02; рыбы, от 20.02 до 20.03; овен, от 21.03 до 20.04; телец, от 21.01 до 21.05; близнецы, от 22.05 до 21.06; рак, от 22.06 до 22.07; лев, от 23.07 до 23.08; дева, от 24.08 до 23.09; весы, от 24.09 до 23.10; скорпион, от 24.10 до 22.11; стрелец, от 23.11 до 21.12; козерог, от 22.01 до 20.02. Требуемая дата должна передваться программе через аргумент командной строки ее вызова. Программа должна обеспечивать обработку даты, указанной либо в цифровом формате, в котором номер месяца года и число месяца разделяют символы косой черты (‘/’) или дефиса (‘-‘), либо в алфавитно цифровом формате, где используется сокращенное англоязычное название месяца (Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec) и число месяца после запятой. Латинское название знака зодиака, соответствующего указной дате, должно отображаться через поток стандартного вывода (stdout).
Основания для разработки
«Учебный план» - документ, на основание которого ведется разработка.
Кафедра РК6 - организация, утвердившая этот документ.
Назначение разработки
Программа Н25 предназначена для определения знака зодиака по дате года.
Требования к программе или программному изделию
-
Требования к функциональным характеристикам
Исходные данные передаются программе через аргументы командной строки её вызова.
В качестве исходных данных программе должно передаваться целое положительное числа.
Результат работы программы отображается через поток stdout.
-
Требования к надежности
Программа должна быть устойчива к вводу некорректных данных. Корректный выход из программы должен осуществляться после выполнения соответствующего вычисления.
-
Условия эксплуатации
Без ограничений.
-
Требования к составу и параметрам технических средств
IBM совместимый персональный компьютер.
-
Требования к информационной и программной совместимости
Программа предназначена для работы в ОС Linux и ОС Windows с использованием командной строки.
-
Требования к маркировке и упаковке
Без ограничений.
-
Требования к транспортированию и хранению
Транспортировка и хранение осуществляется на любых известных носителях надлежащего качества.
-
Специальные требования
Программа должна быть совместима с ОС Windows на уровне исходного кода.
Требования к программной документации
Основной программной документацией является «Текст программы»
Технико-экономические показатели
Программа способна эффективно функционировать на любых персональных компьютерах, ноутбуках и серверах с процессором не ниже i386, кроме того, не требует от пользователей дополнительных усилий по её освоению, что даёт возможность её широкого применения на предприятиях и использования частными лицами.
Стадии и этапы разработки
-
Предпроектное исследование. Изучая широко известные программные продукты, было выявлено отсутствие аналогичных программ, способных реализовать поставленную задачу.
-
Экскизное и техническое проектирование. Написание программы велось на языке высокого уровня С/С++.
-
Изготовление опытного образца производилось в среде разработки OS Linux Mandriva 2006 с использованием CC компилятора.
-
Испытание опытного образца выявило отсутствие ошибок и утечек системных ресурсов.
Порядок контроля и приёмки
Программа должна пройти испытания на устойчивость работы и правильность получаемых результатов при вводе пользователем любых данных.
Правила ввода данных:
Данные вводятся через аргументы командной строки вызова программы в формате
bash$ H24 dd/mm
или
bash$ H24 dd-mm
или
bash$ H24 MM, dd
Результат, в случае корректности аргумента, представляет собой латинское название знака зодиака, соответствующего указной дате, отображенное через поток стандартного вывода (stdout).
Описание алгоритма.
В программе организована структура data в которой хранятся параметры даты года (месяц и число). В функции main объявлена структурa origin. Указатель pp ссылается на структуру origin. Полученные через аргументы командной строки параметры, передаются функции Proverka. В функции Proverka задан массив а, который инициализирован, в соответствии с номером элемента, максимальным числом дней соответствующего месяца. Изначально происходит проверка на количество аргументов командной строки, если количество отлично от 2, то программа аварийно завершается. Из функции Proverka вызывается функция return_month_number, которой передаются аргументы командной строки. В функции return_month_number происходит обработка полученных из командной строки данных. С помощью библиотечных функций tolower, isalpha, isdigit, strncmp, strchr обрабатываются данные. Сначала символы аргументов приводится к нижнему регистру с помощью функции tolower, затем, если присутствует запятая, присутствие которой определяется функцией strchr, с помощью функции strncmp происходит сравнение введенной даты в алфавитно-цифровом фомате с определенными в массиве а сокращенными англоязычными названиями месяцев. Далее полученному месяцу ставим в соответствие номер этого месяца, который сохраняем в члене month структуры data. Затем получаем с помощью функций isdigit, atoi, isalpha день месяца и присваиваем ее элементу day структуры data. Если в строке, полученной из командной строки встречаются символы «/» или «-» , то задействуется вторая часть функции return_month_number, в которой происходит проверка на корректность ввода данных. Далее находим номер месяца, который сохраняем в члене month структуры data. Затем получаем с помощью функций isdigit, atoi, isalpha день месяца и присваиваем ее элементу day структуры data.
Возвращаемся в функцию Proverka, далее мы сравниваем номер месяца с максимальным возможным (12) и проверяем день месяца в соответствии с указанными в массиве а максимальными значениями для соответствующего месяца. Если все впорядке – продолжаем работу, иначе функция выдает в поток stderr сообщение об ошибке и аварийно завершается работа программы.
Использованная литература.
-
Волосатова Т.М., Лекции “Программирование на языке высокого уровня”. МГТУ 2006г.
-
Б.Керниган, Д. Ритчи “Язык программирования Си”, второе издание, Москва 1992.
Текст программы
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <ctype.h>
#include <string.h>
// tyta xpaHim Dady i Mec9LI,
struct data {
int day;
int month;
};
int main(int argc, char *argv[])
{
struct data *Proverka(struct data *pp, int argc, char *argv[]);
int return_month_number(char **argv, struct data *pp);
int Measure(struct data *pp);
struct data origin, *pp;
pp = &origin;
pp = Proverka( pp , argc, argv); //tyta 3aI7ycKaeTc9 I7poBePka Ha4 ycJIoBuu'
Measure(pp);
return 0;
}
struct data *Proverka(struct data *pp, int argc, char *argv[])
{
int i, a[13]={0, 31, 29 , 31 , 30, 31, 30, 31, 31, 30, 31, 30, 31} ;
if(argc!=2) {
fprintf(stderr, "Incorrect parameters, bash write month,day or mm/dd or mm-dd \n");
exit(-1);}
return_month_number(argv, pp);
if((pp->month)>13) { fprintf(stderr, "Incorrect Month"); exit(-1);}
if((pp->day)>(a[pp->month])) { fprintf(stderr, "Incorrect DAY of Month"); exit(-1);}
return pp;
}
int return_month_number(char **argv, struct data *pp)
{
const char *month_name[14] = { "Incorrect data", "jan", "feb", "mar", "apr","may", "jun", "jul", "aug", "sep", "oct", "nov", "dec", "Incorrect data"};
char *i, a[1][3];
int month_number = 0, n,j, day_number;
for(j=0;argv[1][j]!='\0';j++)
{argv[1][j] = tolower(argv[1][j]);
if(j>5){ fprintf(stderr, "Incorrect data\n ");exit(-1); }
}
if((i = strchr(argv[1], ','))!=0){ //EcJIu BcTpe4aeTc9 3aI79Ta9 - cpaBHuBaeM 4to BBeJIu u Mec9c
for(n=0;(i!=0)&&(n<=13);n++)
i = strncmp(argv[1], month_name[n], 3);
if(n>13){fprintf(stderr, "\n %s \n", month_name[13]); exit(-1);}
pp->month = --n;
for(n=0, j=4; (argv[1][j]!='\0')&&(n<2); j++)
{ if(isalpha(argv[1][j])){ fprintf(stderr, "%s\n", month_name[13]); exit(-1);}
if(isdigit(argv[1][j]))
{a[0][n] = argv[1][j]; n++;}}
pp->day = atoi(a[0]);
}
else { //EcJIu Het ecJIu ecTb - ili /, to o6paa6aTbIBaeM DaHHbIe
if(argv[1][5]!='\0') {fprintf(stderr, "%s\n", month_name[13]); exit(-1);}
if(((i = strchr(argv[1], '-'))!=0)||((i = strchr(argv[1], '/'))!=0)){
for(n=0, j=0; ((argv[1][j]!='-')||(argv[1][j]!='/'))&&(n<2); j++)
{ if(isalpha(argv[1][j])){ fprintf(stderr, "%s\n", month_name[13]); exit(-1);}
a[0][n] = argv[1][j]; n++;}
pp->day = atoi(a[0]);
for(n=0, ++j; (argv[1][j]!='\0')&&(n<2); j++)
{ if(isalpha(argv[1][j])){ fprintf(stderr, "%s\n", month_name[13]); exit(-1);}
a[0][n] = argv[1][j]; n++;}
pp->month = atoi(a[0]);
}
else { fprintf(stderr, "%s\n", month_name[13]); exit(-1);}
}
}
int Measure(struct data *pp)
{ //Tyt CaMa CopTuRoBka
switch(pp->month){
case 1:
{if((pp->day)<21){fprintf(stdout, "\n You are CAPRICON\n");}
if((pp->day)>20)fprintf(stdout, "\n You are AQUARIUS \n");}
break;
case 2:
{if((pp->day)<20){fprintf(stdout, "\n You are AQUARIUS\n");}
if((pp->day)>19)fprintf(stdout, "\n You are PISCES \n");}
break;
case 3:
{if((pp->day)<21){fprintf(stdout, "\n You are PISCES\n");}
if((pp->day)>20)fprintf(stdout, "\n You are ARIES \n");}
break;
case 4:
{if((pp->day)<21){fprintf(stdout, "\n You are ARIES\n");}
if((pp->day)>20)fprintf(stdout, "\n You are TAUTUS\n");}
break;
case 5:
{if((pp->day)<22){fprintf(stdout, "\n You are TAURUS\n");}
if((pp->day)>21)fprintf(stdout, "\n You are GEMINI\n");}
break;
case 6:
{if((pp->day)<22){fprintf(stdout, "\n You are GEMINI\n");}
if((pp->day)>21)fprintf(stdout, "\n You are CANCER \n");}
break;
case 7:
{if((pp->day)<23){fprintf(stdout, "\n You are CANCER\n");}
if((pp->day)>22)fprintf(stdout, "\n You are LEO \n");}
break;
case 8:
{if((pp->day)<24){fprintf(stdout, "\n You are LEO\n");}
if((pp->day)>23)fprintf(stdout, "\n You are VIGRO \n");}
break;
case 9:
{if((pp->day)<24){fprintf(stdout, "\n You are VIGRO\n");}
if((pp->day)>23)fprintf(stdout, "\n You are LIBRA \n");}
break;
case 10:
{if((pp->day)<24){fprintf(stdout, "\n You are LIBRA\n");}
if((pp->day)>23)fprintf(stdout, "\n You are SCORPIO \n");}
break;
case 11:
{if((pp->day)<23){fprintf(stdout, "\n You are SCORPIO\n");}
if((pp->day)>22)fprintf(stdout, "\n You are SAGITARIUS \n");}
break;
case 12:
{if((pp->day)<22){fprintf(stdout, "\n You are SAGITARIUS\n");}
if((pp->day)>21)fprintf(stdout, "\n You are AQUARIUS \n");}
break;
}
}