Южно-Уральский государственный университет
Заочный инженерно - экономический факультет
Контрольная (курсовая) работа №2
По Информатике
Выполнил студент- заочник 1го
курса
Шифр – ЭПА-04-588 Группа – 147
«____»___________2008г. «____»___________2008г.
Срок предоставления работы по графику Дата отправки работы
№_____________ по журналу «____»_____________2008г.
___________________ Хусаинов Р.З.
отметка о зачете работы
Преподаватель
____________________
Подпись преподавателя
«____»_____________2008г.
1. Расчет определителя 2го
порядка по введенным четырем целым числам
Программа:
/*Расчет определителя 2го порядка по введенным 4-м целым числам*/
#include <stdio.h> /*подключение файла библиотеки*/
#include <conio.h> /*подключение файла библиотеки*/
main () /*главная функция*/
{
int a1,a2,a3,a4,b; /*объявление переменных*/
clrscr (); /*очистка экрана*/
printf ("nnttРасчет определителя 2-го порядкаnnnr");
printf ("tВведите 1-й элемент 1-й строки - "); /*ввод значений*/
scanf ("%d",&a1);
printf ("tВведите 2-й элемент 1-й строки - ");
scanf ("%d",&a2);
printf ("tВведите 1-й элемент 2-й строки - ");
scanf ("%d",&a3);
printf ("tВведите 2-й элемент 2-й строки - ");
scanf ("%d",&a4);
b=a1*a4-a2*a3 /*расчет определителя*/
printf ("nntttОпределитель матрицы = %d",b); /*вывод результата*/
getch (); /*ожидание нажатия любой клавиши*/
}
Пример исполнения:
Алгоритм:
2. Вводится натуральное число меньше 256. Поменять местами цифры десятков и единиц и вывести на экран новое число
Программа:
/* Поменять местами десятки с единицами натурального числа меньше 256*/
#include <conio.h>
#include <stdio.h>
main()
{
int a,b,c,d,e;
clrscr ();
printf ("tЗамена местами десяток с единицами в натуральном числеnnnr");
printf ("taВведите натуральное число меньше 256ntЭто число - ");
scanf ("%d",&a);
/*Проверяем число на соответствие условию*/
if (a>0)
{
if (a<256)
{/*Число удовлетворяет условию*/
b=a%10; /*Находим еденицы*/
c=(a%100)-b; /*Находим десятки*/
d=(a%1000)-(c+b); /*Находим сотни*/
e=d+b*10+c/10; /*Переставляем разряды ед. дес.*/
printf ("nrtПосле замены разрядов получилось число %d",e);
}
else/*Выход если число больше 256*/
printf ("taЧисло %d не соответствует условию",a);
}
else/*Выход если число <= 0*/
printf ("taЧто читать не умеешь? Только натуральные!");
getch ();
}
Пример исполнения:
Алгоритм:
3.Вводится число типа беззнаковое длинное целое. Определить состояние 20-го и 21-го бита. Установить в нулевое состояние 4-й и 5-й биты числа
Программа:
/*программа для определения 20-го, 21-го и сброса 4-го и 5-го бита числа */
#include <conio.h>
#include <stdio.h>
main ()
{
unsigned long a,b,ms20=524288,ms21=1048576,m045=2147483623;
/*ms20 маска для определения 20-го бита,*/
/*ms21 маска для определения 21-го бита,*/
/*m045 маска для сброса 4-го и 5-го бита в веденном числе.*/
clrscr ();
printf ("Введите положительное целое число от 0 до 2'147'483'647 - ");
scanf ("%ld",&a);
if (a<=2147483647 && a>0) /*Проверка правильности ввода*/
{
b=a&ms20; /*Проверка 20-го бита*/
if(b==0)
{
printf ("20-й бит в числе %010ld равен -"0"nr",a);
}
else
printf ("20-й бит в числе %010ld равен -"1"nr",a);
b=a&ms21; /* Проверка 21-го бита*/
if(b==0)
{
printf ("21-й бит в числе %010ld равен -"0"nr",a);
}
else
printf ("21-й бит в числе %010ld равен -"1"nr",a);
b=a&m045; /*Сброс 4-го и 5-го бита*/
printf ("После сброса 4-го и 5-го бита число равно %010ldnr",b);
}
else
printf ("Неправильно введено число");
getch ();
}
Пример исполнения:
Алгоритм:
4. Вывести на экран таблицу
N
значений заданной функции:
y
=
sin
(
x
)+
sin
(3
x
)/3/. Диапазон изменения переменной
x
[0; 6.28]. Количество точек таблицы
N
=100, ширина поля вывода переменных
x
и
y
– 9 позиций, точность- 4 позиции
Программа:
/* Программа для расчета заданной функции на 100 значений при Х=[0;6.28]*/
#include<stdio.h>
#include<math.h>
#include<conio.h>
main()
{
float x=0,y,dx=6.28/100; /*dx шаг приращения х*/
int n;
clrscr(); /*рисуем шапку таблицы*/
printf("| № | X | Y |n");
printf("---------------------------n");
for (n=1;n<=100;n++,x=x+dx) /*... и значение х*/
{
y=sin(x)+sin(3*x)/3; /* значение у */
printf("|%3d|%9.4f |%9.4f|n",n,x,y);
if((n%20)==0)
{
printf("---------------------------"); /*низ таблицы на экране*/
gotoxy(3,24);
if (n==100)
cprintf (" Расчет закончен. nr");
cprintf ("Для продолжения нажмите пробел.");
getch();
gotoxy(1,3); /*возврат курсора под шапку табл.*/
}
else
;
}
}
Пример исполнения:
Алгоритм:
6. Привести краткое описание указанного элемента языка Си: функции преобразования чисел в строки и наоборот, синтаксис, примеры использования
Стандартные функции преобразования данных.
Функции преобразования строки-символов в число.
· double atof(char *string); (stdlib.h)
· int atoi(char *string); (stdlib.h)
· long atol(char *string); (stdlib.h)
Функция atof преобразует строку в вещественное число двойной точности.
Функция atoi преобразует строку в целое число.
Функция atol преобразует строку в длинное целое число.
Во всех функциях строка string является последовательностью символов, которая может интерпретироваться, как число. Чтение символов из строки происходит до тех пор, пока не будет встречен символ, который не может быть распознан, как часть числа, например ‘0’.
Для функции atof строка может иметь следующий вид:
“[пробелы][знак][цифры][.цифры][e[знак]цифры]”
Для функций atoi и atoll строка может иметь следующий вид:
“[пробелы][знак][цифры]”
Функция strtod() преобразует строку в вещественное число двойной точности, и позволяет указывать символ, на котором необходимо закончить чтение.
Функции strtol(), strtoul(), позволяют преобразовывать строки в различные системы счисления.
Функции преобразования вещественных чисел в строку символов.
· char *ecvt(double value,int ndigits, int *decptr,int *signptr); (stdlib.h)
· char *fcvt(double value,int ndec, int *decptr,int *signptr); (stdlib.h)
· char *gcvt(double value,int ndec, char *buffer); (stdlib.h)
Эти функции применяют для вывода значений переменных в графическом режиме.
Функция ecvt
Преобразовывает число с плавающей точкой двойной точности в строку символов. При этом функция возвращает указатель на строку, а строка содержит ndigits цифр числа value, и нулевой байт. Если цифр в числе value больше, чем указано параметром ndigits, то отсекаются младшие разряды. Если цифр в числе value меньше, чем указано в параметре ndigits, число дополняется нулями. Возвращаемая строка содержит только цифры. Позиции точки и знака стоят на 3 и 4 местах, *decptr указывает на целое число, значение которого определяет позицию десятичной точки. '0', или отрицательное значение говорят о том, что десятичная точка стоит слева от первой цифры, например:
Число |
Правильное значение decptr |
0.0007568905123 |
-3 |
0.7568905123 |
0 |
75.68905123 |
2 |
Если signptr==0, то число положительное, при остальных значениях – отрицательное.
Число значащих цифр после запятой для формата float – 6, для формата double – 16.
Функция fcvt
Работает так же, как и предыдущая функция, но параметр ndec определяет не общее количество цифр в строке, а количество цифр после десятичной точки. Если число цифр после десятичной точки в числе value больше, чем параметр ndec, то число округляется. Если меньше, то строка дополняется нулями.
Функция gcvt
Функция преобразует число в строку в определённом формате
Функции преобразования целых чисел в строку символов.
· char *itoa (int value, char *string, int radix) (stdlib.h)
· char *ltoa (long int value, char *string, int radix) (stdlib.h)
· char *ultoa (unsigned long int value, char *string, int radix) (stdlib.h)
Функция itoa
Функция преобразует число целого типа int и воpвращает строку string. Параметр radix определяет систему счисления для представления результата. radix может изменяться от 2 до 36. Если value отрицательно, а radix равен 10, то первый знак “-”.
Функция ltoa
Функция работает так же, как и itoa, но преобразует в строку число типа long int – длинное целое.
Функция ultoa
Функция работает так же, как и itoa, но преобразует в строку число типа unsigned long int – беззнаковое длинное целое.
Пример:
#include <stdio.h>
#include <stlib.h>
void main()
{
int value=5382;
char string[10];
itoa(value,string,10);
printf(“Строка string: %s”,string);
value=37;
itoa(value,string,2);
printf(“Строка string: %s”,string);
}
Результат работы программы:
Строка string: 5382
Строка string: 100101
8. Написать программу БЕГУЩАЯ СТРОКА в текстовом режиме экрана. Заданная строка появляется слева в центре экрана и перемещается направо, после того, как она скроется справа, она вновь появляется слева
Программа:
/*Программа БЕГУЩАЯ СТРОКА*/
#include <conio.h>
#include <stdio.h>
main()
{
char ch,runne_line[41]=" 1234567890123456789012345678901234567890";
/*^-для затирания последнего символа в Б.С.*/
char line[80]=" ";
int i=0,x=40,c,z,j,t1,t=30000;
/*i,c - количество символов в строке
*x,z - указатель на элемент массивов line и runne_line
*t,t1 -задержка времени в тиках.*/
clrscr();
printf("nttВведите заданную строку.n");
printf("tСтроку, не более 40 символов, закончить "Enter".n");
while((ch=getch())!=0x0d)
{
i++;
if(i==41) /* 41-й символ не вводим*/
{
gotoxy(8,5);
cprintf("Символов больше 40, жми "Enter".a");
i--;
}
else
{
runne_line[i]=ch; /*начинаем заполнять с 1-го элемента не с 0-го*/
gotoxy((i+1),4);
cprintf("%c",ch);
}
}
gotoxy(1,5); /*Для затирки предыд. сообщ. если оно есть.*/
cprintf(" "Y"-Запустить БЕГУЩУЮ СТРОКУ.");
gotoxy(11,6);
cprintf(""Пробел"-Выйти из программы.");
switch(ch=getch())
{
case 'Y':/*во всех регистрах и раскладках*/
case 'y':
case 'н':
case 'Н':
gotoxy(1,5);
cprintf(" ");
/* определяем следующий элемент в выводимом массиве line*/
for(x=40;x<82;x++) /* цикл бесконечный*/
{
/*Если нажата любая клавиша выйти из цикла*/
if(kbhit()) break;
if(x>79) /* следующий д.б. <= 79*/
x=0; /* иначе = 0*/
z=x;
/*переписываем из заданного в выводимый*/
for(c=i;c>=0;c--,z--)
{
if(z<0)
z=79;
if(z>79)
z=0;
/*выводим на экран*/
line[z]=runne_line[c];
for(j=80;j>=1;j--)
{
gotoxy(j,24);
cprintf("%c",line[(j-1)]);
/*сделать задержку*/
for(t1=t;t1!=0;t1--);
}
}
}
break;
default:;
}
}
Пример исполнения:
Алгоритм:
Работа над ошибками:
1. Расчет определителя 2го
порядка по введенным четырем целым числам.
Программа:
/*Расчет определителя 2го порядка по введеным 4-м целым числам*/
#include <stdio.h> /*подключение файла библиотеки*/
#include <conio.h> /*подключение файла библиотеки*/
main () /*главная функция*/
{
int a[2][2],i,j,b,n=2; /*объявление переменных*
*i-строка, j-столбец, n-порядок
определителя*/
clrscr (); /*очистка экрана*/
printf ("nnttРасчет определителя %d-го порядкаn",n);
/*ввод значений*/
for (i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
cprintf ("Введите %d-й элемент %d-й строки - ",j+1,i+1);
scanf ("%d",&a[j][i]);
}
}
/*считаем определитель*/
b=a[0][0]*a[1][1]-a[1][0]*a[0][1];
/*выводим на экран*/
/*clrscr();*/
printf ("nt|%-3d %3d|",a[0][0],a[0][1]);
printf ("nt| | = %d",b);
printf ("nt|%-3d %3d|",a[1][0],a[1][1]);
getch (); /*ожидание нажатия любой клавиши*/
}
Пример исполнения:
Алгоритм:
3.
ms20, ms21, ms045 получены следующим способом:
1) 00000000000010000000000000000000(2)
=524288(10)
= ms20
^20й
бит целого длинного беззнакового числа.
2) 00000000000100000000000000000000(2)
=1048576(10)
= ms21
^21й
бит целого длинного беззнакового числа.
3) 11111111111111111111111111100111(2)
=4294967271(10)
= ms045 или,
01111111111111111111111111100111(2)
=2147483623(10)
= ms045
^32 бит –знак числа в длинном целом. В данном примере можно не учитывать, что не скажется на результате, так как нужно определить 20 и21 бит и сбросить 4 и 5. Необходимо лишь, чтобы вводимое число было в диапазоне от 0 до 01111111111111111111111111111111(2)
=2147483647(10)
и проверить правильность ввода.
У меня в компьютере получается так:
даже если
scanf ("%ld",&a);
заменить на
scanf ("%u",&a);
строка 12 и соответственно форматный вывод (строки 18, 21, 26, 29, 32).
Такое же непонятное и с 11111111111111111111111111100111(2)
=4294967271(10)
= ms045.
4.
dx=6,28/99 т.к. 99 шагов между точками таблицы. Пример выполнения программы выглядит так:
8.
1 char ch,runne_line[41]=" 1234567890123456789012345678901234567890";
Пробел необходим, для того, чтобы затереть первый символ бегущей строки в массиве line, остающийся при смещении её на знакоместо вправо.
1234567890… в процессе отладки видно где какое знакоместо. В принципе можно убрать, но и так не мешает. Эту строку можно заменить на следующее:
char ch,runne_line[41], runne_line[0]=’ ‘:
2 Посимвольный ввод организовал по следующим причинам.
Подсчет количества символов в бегущей строке. Необходим для того чтобы не делать лишних циклов при перезаписи из runne_line в line. Можно воспользоваться strlen (s), но тогда нужно #include<string.h> , что увеличит объем занимаемой памяти. К тому же функция strlen (s) не учитывает пробелы (пробел – ограничитель длинны строки). Поэтому невозможно организовать бегущую строку из двух и более слов. Посимвольный вывод для того чтобы обеспечить плавность сдвига строки.
Без посимвольного ввода программа выглядит так:
/*Программа БЕГУЩАЯ СТРОКА*/
#include <conio.h>
#include <stdio.h>
#include <string.h>
main()
{
char ch,runne_line[41];
char line[80]=" ";
int i,x=40,c,z,j;
long int t1,t=232000;
/*i,c - количество символов в строке
*x,z - указатель на элемент массивов line и runne_line
*t,t1 -задержка времени в тиках.*/
clrscr();
printf("nttВведите заданную строку.n");
printf("tСтроку, не более 40 символов, закончить "Enter".n");
scanf("%s",runne_line); /*вводим строку которая будет бежать*/
for(i=40;i>=0;i--) /* для освобождения [0] и записи в него ' '*/
{
runne_line[i+1]=runne_line[i];
}
runne_line[0]=' ';
i=strlen(runne_line);
gotoxy(1,5);
cprintf(" "Y"-Запустить БЕГУЩУЮ СТРОКУ.");
gotoxy(11,6);
cprintf(""Пробел"-Выйти из программы.");
switch(ch=getch())
{
case 'Y':/*во всех регистрах и раскладках*/
case 'y':
case 'н':
case 'Н':
gotoxy(1,5);
cprintf(" ");
/* определяем следующий элемент в выводимом массиве line*/
for(x=40;x<82;x++) /* цикл бесконечный*/
{
/*Если нажата любая клавиша выйти из цикла*/
if(kbhit()) break;
if(x>79) /* следующий д.б. <= 79*/
x=0; /* иначе = 0*/
z=x;
/*переписываем из заданного в выводимый*/
for(c=i;c>=0;c--,z--)
{
if(z<0)
z=79;
if(z>79)
z=0;
line[z]=runne_line[c];
/*выводим на экран*/
for(j=80;j>=1;j--)
{
gotoxy(j,24);
cprintf("%c",line[(j-1)]);
/*сделать задержку*/
for(t1=t;t1!=0;t1--);
}
}
}
break;
default:;
}
}