Читаем Конец холивара полностью

floor (x) – наибольшее целое, не превышающее значения х.

labs (x) – абсолютное значение целого аргумента long x.

log (x) – ln x.

log10 (x) – log 10 x.

pow (x, y) – х в степени у.

sin (x) – синус x – угол задается в радианах.

sqrt (x) – квадратный корень x.

tan (x) – тангенс x – угол задается в радианах.


Это только основные функции, которые могут понадобиться на первом этапе освоения языка.

Оператор присваивания

x = … – пусть x будет…

2. Программные конструкции

2.1. Ветвление (выбор)


2.1.1. Альтернатива (условный оператор)

Пример 2.1: Вычисление значений функции Y=1/X.


#include


int main ()

{

float x;

printf (“Введите число\n”);

scanf (”%f”, &x);

if (x!= 0)

printf (“Y=1/X=%f\n”, 1/x);

else

printf (“0 не входит в область определения функции Y=1/X\n”);

getchar ();


return 0;


}

2.1.2. Неполный условный оператор

Пример 2.2: Если X <3, то вывести на печать значение X.


if (x <3)

printf (”%f”, x);

> – больше

– меньше

> = – не меньше

<= – не больше

= = – равно

!= – не равно


! – не

&& – и

|| – или


Примеры сложных (составных) условий:


if (a == 2 && b> 5)…

if (a == 2 || b> 5)…

if (! (a == 4))…

2.1.3. Оператор варианта (переключатель)

Переключатель в C существенно отличается от подобного в Pascal. Например, в нём нельзя в одном варианте выбора предлагать через запятую несколько констант. Зато у переключателя в C есть вариант по умолчанию. Поэтому, я привожу для разбора другой, но тоже простой и наглядный, пример.


Пример 2.3: При вводе номера дня недели программа сообщает название рабочего дня или сообщение “Выходной!”


#include


int main ()

{

int n;


printf (“Введите номер дня недели\n”);


scanf (”%d”, &n);


switch (n)

{

case 1: printf (“Понедельник\n”); break;

case 2: printf (“Вторник\n”); break;

case 3: printf (“Среда\n”); break;

case 4: printf (“Четверг\n”); break;

case 5: printf (“Пятница\n”); break;

case 6: printf (“Выходной!\n”); break;

case 7: printf (“Выходной!\n”); break;

default: printf (“Вы заработались :-) \n”);

}

getchar ();


return 0;


}


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


SWITCH – переключатель, железнодорожная стрелка.

CASE – случай, обстоятельство.

BREAK – прервать.

DEFAULT – отсутствие, исключение, по умолчанию.

2.2. Повторение (операторы цикла)


2.2.1. Цикл типа “пока” (цикл с предусловием)

Пример 2.4: Программа находит наибольший общий делитель двух целых чисел.


#include

#include


int main ()

{

int x, y;


printf (“Введите два целых числа через пробел\n”);

int r = scanf (”%d%d”, &x, &y);


assert (r == 2);


while (x!= y)

if (x> y)

x = x – y;

else

y = y – x;

printf (“НОД=%d\n”, x);


getchar ();


return 0;


}


Для проверки соответствия ввода пользователя требованиям программы мы сохраняем (=) результат выполнения scanf – количество успешно измененных переменных – в целочисленной переменной с именем r (int r), после чего требуем равенства её значения двум


(assert (r == 2);


Для этого и нужна директива препроцессора


#include

2.2.2. Цикл, который выполняется не меньше одного раза

Обратите внимание, что в цикле используется условие продолжения, а не завершения повторения! Это не цикл “до”, подобный REPEAT… UNTIL в Pascal, хотя назначение его то же – позволить телу цикла выполнится хотя бы один раз.


Пример 2.5: Решение предыдущей задачи.


#include

#include


int main ()

{

int x, y;


printf (“Введите два целых числа через пробел\n”);


int r = scanf (”%d%d”, &x, &y);


assert (r == 2);


do

if (x> y)

x = x – y;

else

y = y – x;

while (x!= y);


printf (“НОД=%d\n”, x);


getchar ();


return 0;


}

2.2.3. Цикл с параметром (со счётчиком)

Пример 2.6: Вычислить факториал числа (n!=1×2×3×…×n).


#include


int main ()

{

int f=1, k, n;


printf (“Введите целое положительное число\n”);


scanf (”%d”, &n);


for (k=1; k <=n; k++)

f=f*k;

printf (“n!=%d\n”, f);


getchar ();


return 0;


}


Перейти на страницу:

Похожие книги

C++ Primer Plus
C++ Primer Plus

C++ Primer Plus is a carefully crafted, complete tutorial on one of the most significant and widely used programming languages today. An accessible and easy-to-use self-study guide, this book is appropriate for both serious students of programming as well as developers already proficient in other languages.The sixth edition of C++ Primer Plus has been updated and expanded to cover the latest developments in C++, including a detailed look at the new C++11 standard.Author and educator Stephen Prata has created an introduction to C++ that is instructive, clear, and insightful. Fundamental programming concepts are explained along with details of the C++ language. Many short, practical examples illustrate just one or two concepts at a time, encouraging readers to master new topics by immediately putting them to use.Review questions and programming exercises at the end of each chapter help readers zero in on the most critical information and digest the most difficult concepts.In C++ Primer Plus, you'll find depth, breadth, and a variety of teaching techniques and tools to enhance your learning:• A new detailed chapter on the changes and additional capabilities introduced in the C++11 standard• Complete, integrated discussion of both basic C language and additional C++ features• Clear guidance about when and why to use a feature• Hands-on learning with concise and simple examples that develop your understanding a concept or two at a time• Hundreds of practical sample programs• Review questions and programming exercises at the end of each chapter to test your understanding• Coverage of generic C++ gives you the greatest possible flexibility• Teaches the ISO standard, including discussions of templates, the Standard Template Library, the string class, exceptions, RTTI, and namespaces

Стивен Прата

Программирование, программы, базы данных
Секреты приложений Google
Секреты приложений Google

Даже продвинутые пользователи Интернета не подозревают о тех огромных возможностях, которые предоставляют сервисы Google. Автор рассказывает о таких «секретах» сервисов, которые просто немедленно хочется использовать! Создавать сайты и презентации, бродить по улочкам Парижа, изучать звездное небо – все это доступно каждому, кто сидит у экрана монитора и имеет доступ в Интернет. Книга научит вас работать с веб-приложениями и тысячекратно увеличить свои возможности с помощью новейших технологий. Она написана легким, доступным языком и не требует от читателя наличия каких-либо специальных знаний. Книга содержит множество примеров, иллюстраций и будет полезна всем, кто не стоит на месте и стремится сделать свою жизнь более насыщенной и интересной.

Денис Балуев , Денис Игоревич Балуев

Программирование, программы, базы данных / Интернет / Программное обеспечение / Книги по IT