Типизированные и нетипизированные файлы. Сборник задач по курсу

Факультет

Компьютерных наук

 

 

Сборник задач по курсу

По программированию

 

для студентов специальности 230201

«Информационные системы и технологии»

 

Составители:

Н.А. Тюкачев

Е.Е. Михайлова

Г.Э. Вощинская

Е.М. Михайлов

 


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

Сборник задач рассчитан на студентов дневного и вечерних отделений, изучающих программирование.

 

Рецензент: д.ф.-м.н., зав. каф. ПОиАИС Артемов М.А.

 

Печатается по решению ученого совета

факультета компьютерных наук

Воронежского государственного университета

 

Ó Коллектив авторов, 2010

Ó Оформление.

Воронежский государственный университет, 2010

 


Линейные алгоритмы

1. Составить программу для решения системы двух линейных уравнений с двумя неизвестными.

Указание

Значение неизвестных x, y системы уравнений


находятся по формулам

.

Проверить, что .

2. Подсчитать, сколько очков набрала команда в первом круге чемпионата по хоккею, если известно, что m встреч она выиграла, n встреч проиграла, k встреч закончились ничьими.

Указание

За выигрыш команда получает два очка, за ничью — 1 очко, за проигрыш — 0 очков.

3. Известны длины сторон a, b, c треугольника. Вычислить высоты этого треугольника.

Указание

Высоты треугольника вычисляются по формулам:

где .

4. Составить программу для вычисления времени t встречи автомобилей, движущихся равноускоренно навстречу друг другу, если известны их скорости V1 и V2, ускорения а1 и а2 и начальное расстояние S между ними.

Указание.

Расстояние S1, пройденное первым автомобилем, вычисляется по формуле ; расстояние, пройденное вторым автомобилем, вычисляется по формуле . Время t встречи автомобилей определяется из уравнения ,

откуда .

 

5. Найти x из пропорции .

6. Сколько процентов от А+ВС приходится на А? На В? На С?

7. Составить программу вычисления идеального веса человека по его росту, при условии, что идеальный_вес(кг) = рост(см) - 100.

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

9. Розничная цена мужского костюма составляет R рублей. Наценка магазина составляет T% от оптовой цены. Составить программу определения оптовой цены костюма.

10. Зарплата сотрудника частной фирмы r рублей в месяц. Сколько денег он получит за полгода после вычета налогов в размере t% ежемесячно и s% за полгода?

11. Даны координаты вершин некоторого треугольника. Вычислить его периметр.

12. Смешано V1 литров воды температуры t1 с V2 литрами воды температуры t2. Составить программу вычисления объема и температуры образованной смеси.

13. Определить стоимость набора, в который входят следующие конфеты:

Название Вес Стоимость 1кг
Петровские 200г K руб.
Воронежские 300г P руб.
Чародейка 250г R руб.
Факел 150г B руб.
Ласточка 200г L руб.
Стоимость упаковки — U руб.

14. Сколько времени в минутах затратит школьник на дорогу от школы до стадиона, если известна длина этого расстояния S км и средняя скорость движения школьника V км/ч.

15. В квадрат вписана окружность (рис. 1.3). Определить площадь заштрихованной части фигуры, если известна длина стороны квадрата.

16. В квадрат вписана окружность (рис. 1.3). Определить площадь заштрихованной части фигуры, если известен радиус окружности.

17. В квадрат вписана окружность (рис. 1.4). Определить площадь заштрихованной части фигуры, если известна длина стороны квадрата.

           
     

Рис. 1.3 Рис. 1.4 Рис. 1.5

18. В квадрат вписана окружность (рис. 1.5). Определить площадь заштрихованной части фигуры, если известна длина стороны квадрата.

19. Даны два ненулевых числа. Найти их сумму, разность, произведение и частное.

20. Даны два числа. Найти среднее арифметическое их квадратов и среднее арифметическое их модулей.

21. Скорость лодки в стоячей воде V км/ч, скорость течения реки U км/ч (U < V). Время движения лодки по озеру T1 ч, а по реке (против течения) — T2 ч. Определить путь S, пройденный лодкой.

22. Скорость первого автомобиля V1 км/ч, второго — V2 км/ч, расстояние между ними S км. Определить расстояние между ними через T часов, если автомобили удаляются друг от друга.

23. Скорость первого автомобиля V1 км/ч, второго — V2 км/ч, расстояние между ними S км. Определить расстояние между ними через T часов, если автомобили первоначально движутся навстречу друг другу.

24. Найти периметр и площадь прямоугольного треугольника, если даны длины его катетов a и b.

 

Логическое выражение

Во всех заданиях данного пункта требуется вывести логическое значение True, если приведенное высказывание для предложенных исходных данных является истинным, и значение False в противном случае. Все числа, для которых указано количество цифр (двузначное число, трехзначное число и т.д.), считаются целыми.

 

1. Проверить истинность высказывания: «Данные числа x, y являются координатами точки, лежащей во второй координатной четверти».

2. Проверить истинность высказывания: «Данные числа x, y являются координатами точки, лежащей в первой или третьей координатной четверти».

3. Проверить истинность высказывания: «Точка с координатами (x, y) лежит внутри прямоугольника, левая верхняя вершина которого имеет координаты (x1, y1), правая нижняя — (x2, y2), а стороны параллельны координатным осям».

4. Проверить истинность высказывания: «Данное целое число является четным двузначным числом».

5. Проверить истинность высказывания: «Данное целое число является нечетным трехзначным числом».

6. Проверить истинность высказывания: «Среди трех данных целых чисел есть хотя бы одна пара совпадающих».

7. Проверить истинность высказывания: «Среди трех данных целых чисел есть хотя бы одна пара взаимно противоположных».

8. Проверить истинность высказывания: «Сумма цифр данного трехзначного числа является четным числом».

9. Проверить истинность высказывания: «Сумма двух первых цифр данного четырехзначного числа равна сумме двух его последних цифр».

10. Проверить истинность высказывания: «Данное четырехзначное число читается одинаково слева направо и справа налево».

11. Проверить истинность высказывания: «Все цифры данного трехзначного числа различны».

12. Проверить истинность высказывания: «Цифры данного трехзначного числа образуют возрастающую последовательность».

13. Проверить истинность высказывания: «Цифры данного трехзначного числа образуют возрастающую или убывающую последовательность».

14. Проверить истинность высказывания: «Цифры данного трехзначного числа образуют арифметическую прогрессию».

15. Проверить истинность высказывания: «Цифры данного трехзначного числа образуют геометрическую прогрессию».

16. Даны координаты (как целые от 1 до 8) двух различных полей шахматной доски. Если ладья1| король2| слон3| ферзь4| конь5 за один ход может перейти с одного поля на другое, вывести логическое значение True, в противном случае вывести значение False.

Условный оператор

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

2. Ввести три числа. Если они могут быть длинами сторон остроугольного треугольника, вывести их в порядке убывания, вычислить площадь полученного треугольника.

3. Ввести три числа. Если они могут быть длинами сторон тупоугольного треугольника, вывести их в порядке убывания, вычислить площадь полученного треугольника.

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

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

6. Ввести три числа. Если они могут быть длинами сторон разностороннего тупоугольного треугольника, вывести их в порядке возрастания, вычислить площадь полученного треугольника.

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

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

9. Ввести три числа. Если они могут быть длинами сторон разностороннего остроугольного треугольника, вывести их в порядке возрастания, вычислить площадь полученного треугольника.

10. Даны координаты трех точек на плоскости. Если они могут быть вершинами остроугольного треугольника, вывести их в порядке убывания, вычислить площадь полученного треугольника.

11. Даны три числа. Если они могут быть длинами сторон треугольника, определить его вид (прямоугольный, тупоугольный, остроугольный). Вычислить длины его высот и напечатать их в порядке убывания.

12. Составить программу, которая определяла бы вид треугольника (равносторонний, равнобедренный, разносторонний, прямоугольный, тупоугольный, остроугольный), если по данным трём отрезкам его можно построить.

13. Даны координаты трех точек на плоскости. Составить программу, которая определяла бы вид треугольника (равносторонний, равнобедренный, разносторонний, прямоугольный, тупоугольный, остроугольный), если данные координаты вершин позволяют его построить.

14. Даны координаты трех вершин прямоугольника. Определить координаты четвертой вершины.

15. Даны три целых числа. Возвести в квадрат отрицательные числа и в третью степень — положительные (число 0 не изменять).

16. Из трех данных чисел выбрать наименьшее.

17. Из трех данных чисел выбрать наибольшее.

18. Из трех данных чисел выбрать наименьшее и наибольшее.

19. Перераспределить значения переменных X и Y так, чтобы в X оказалось меньшее из этих значений, а в Y — большее.

20. Значения переменных X, Y, Z поменять местами так, чтобы они оказались упорядоченными по возрастанию.

21. Значения переменных X, Y, Z поменять местами так, чтобы они оказались упорядоченными по убыванию.

22. Даны две переменные целого типа: A и B. Если их значения не равны, то присвоить каждой переменной сумму этих значений, а если равны, то присвоить переменным нулевые значения.

23. Даны две переменные целого типа: A и B. Если их значения не равны, то присвоить каждой переменной максимальное из этих значений, а если равны, то присвоить переменным нулевые значения.

24. Даны три переменные: X, Y, Z. Если их значения упорядочены по убыванию, то удвоить их; в противном случае заменить значение каждой переменной на противоположное.

25. Даны три переменные: X, Y, Z. Если их значения упорядочены по возрастанию или убыванию, то удвоить их; в противном случае заменить значение каждой переменной на противоположное.

26. Даны целочисленные координаты точки на плоскости. Если точка не лежит на координатных осях, то вывести 0. Если точка совпадает с началом координат, то вывести 1. Если точка не совпадает с началом координат, но лежит на оси OX или OY, то вывести соответственно 2 или 3.

27. Даны вещественные координаты точки, не лежащей на координатных осях OX и OY. Вывести номер координатной четверти, в которой находится данная точка.

28. На числовой оси расположены три точки: A, B, C. Определить, какая из двух последних точек (B или C) расположена ближе к A, и вывести эту точку и ее расстояние от точки A.

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

30. Дан номер некоторого года (положительное целое число). Вывести соответствующий ему номер столетия, учитывая, что, к примеру, началом 20 столетия был 1901 год.

31. Дан номер некоторого года (положительное целое число). Вывести число дней в этом году, учитывая, что обычный год насчитывает 365 дней, а високосный — 366 дней. Високосным считается год, делящийся на 4, за исключением тех годов, которые делятся на 100 и не делятся на 400 (например, годы 300, 1300 и 1900 не являются високосными, а 1200 и 2000 — являются).

32. Ввести три числа. Если они могут быть длинами сторон прямоугольного треугольника, вывести их в порядке возрастания, вычислить площадь полученного треугольника.

33. Ввести три числа. Если они могут быть длинами сторон остроугольного треугольника, вывести их в порядке убывания, вычислить площадь полученного треугольника.

34. Ввести три числа. Если они могут быть длинами сторон тупоугольного треугольника, вывести их в порядке убывания, вычислить площадь полученного треугольника.

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

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

37. Ввести три числа. Если они могут быть длинами сторон разностороннего тупоугольного треугольника, вывести их в порядке возрастания, вычислить площадь полученного треугольника.

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

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

40. Ввести три числа. Если они могут быть длинами сторон разностороннего остроугольного треугольника, вывести их в порядке возрастания, вычислить площадь полученного треугольника.

41. Даны координаты трех точек на плоскости. Если они могут быть вершинами остроугольного треугольника, вывести их в порядке убывания, вычислить площадь полученного треугольника.

42. Даны три числа. Если они могут быть длинами сторон треугольника, определить его вид (прямоугольный, тупоугольный, остроугольный). Вычислить длины его высот и напечатать их в порядке убывания.

43. Даны координаты трех точек на плоскости. Составить программу, которая определяла бы вид треугольника (равносторонний, равнобедренный, разносторонний, прямоугольный, тупоугольный, остроугольный), если данные координаты вершин позволяют его построить.

44. Даны координаты трех вершин прямоугольника. Определить координаты четвертой вершины.

45. Даны действительные положительные числа a, b, c, x, y. Выяснить, пройдет ли кирпич с ребрами a, b, c в прямоугольное отверстие со сторонами x и y. Просовывать кирпич в отверстие разрешается только так, чтобы каждое из его ребер было параллельно или перпендикулярно каждой из сторон отверстия

 

Циклы

1. Составить программу вычисления суммы вида:

a)

b)

2. Составить программу вычисления при заданных x и a значения функции y вида:

a) ;

b) .

3. Вычислить: ;

4. Написать программу вычисления при заданном x величины y по формуле

.

5. Вычислить .

6. Составить программу для нахождения и печати всех пифагоровых чисел, не превышающих 20.

7. Дано натуральное n. Вычислить значение выражения

8. Даны натуральное число n и действительное число x. Вычислить:

a)

b)

9. Дано натуральное k. Напечатать k-ую цифру последовательности 12345678910111213…, в которой выписаны подряд все натуральные числа.

10. Вычислить x1+x2+…+ x20, если последовательность x1, x2, … образована по следующему закону:

1. ;

2. x1 = 1; x2 = 0.3; xi = (i+1) ×xi – 2 , i = 3, 4, … .

3. x1 = x2 = x3 =1; xi = (i+3) × (xi – 3 –1)+ (i+4) ×xi – 2, i = 4, 5, … .

11. Дано вещественное число x и натуральное число n. Вычислить .

12. Даны вещественные числа a, h, натуральное число n.
Вычислить , где

13. Дано натуральное число n. Вычислить 1×2+2×3×4+…+n× …×2n.

14. При некоторых заданных x, N и E, определяемых вводом, вычислить:

a) сумму N слагаемых заданного вида;

b) сумму тех слагаемых, которые по абсолютной величине больше Е.

Для случая b выполнить суммирование для двух значений Е, отличающихся на порядок, и при этом определить количество слагаемых, включенных в сумму. Сравнить результаты с точным значением функции, для которой данная сумма определяет приближенное значение при x, лежащем в интервале (-R, R).

I) (R=¥).

II) (R=¥).

III) (R=1)

IV) (R=1).

V) (R=1).

VI) (R=1).

VII) (R=1).

VIII) (R=1).

IX) (R=1)

X) (R=1).

XI) (R=1).

XII) (R=1).

XIII) (R=1).

XIV) (R=1).

XV) (R=¥).

XVI) (R=¥).

XVII) (R=¥).

 

17. Дано натуральное число n. Вычислить 1/2+2/3×4+…+n/(n+1) ×(n+2) ×…×2n.

19. Составить программу, нахожения всех простых чисел, не превосходящих заданного натурального значения.

 

Последовательности чисел

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

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

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

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

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

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

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

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

9. Вводится последовательность целых чисел, оканчивающаяся нулём, и состоящая более чем из одного ненулевого элемента. Определить, являются ли вводимые числа числами Фибоначчи.

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

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

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

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

14. Вводится последовательность вещественных чисел, оканчивающаяся нулём, и состоящая более чем из одного ненулевого элемента. Определить, образует ли эта последовательность ряд Фибоначчи.

15. Вводится последовательность вещественных чисел, оканчивающаяся нулём, и состоящая более чем из одного ненулевого элемента. Определить, сумму и количество тех из них, которые принадлежат отрезку [a,b]. a и b вводятся.

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

17. Вводится последовательность вещественных чисел, оканчивающаяся нулём, и состоящая более чем из одного ненулевого элемента. Найти количество и сумму элементов, равных первому отрицательному1| больших, чем первый отрицательный2| меньших, чем первый отрицательный3.

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

19. Вводится последовательность вещественных чисел, оканчивающаяся нулём, и состоящая более чем из одного ненулевого элемента. Найти сумму тех из них, которые находятся, начиная с позиции i, и заканчивая позицией j. i и j вводятся. Если элементов с указанными номерами нет, сообщить об этом.

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

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

22. Вводится последовательность вещественных чисел, оканчивающаяся нулём, и состоящая более чем из одного ненулевого элемента. Определить, образуют ли эта последовательность арифметическую прогрессию.

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

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

25. Вводится последовательность вещественных чисел, оканчивающаяся нулём, и состоящая более чем из одного ненулевого элемента. Определить, сколько из них имеют равных «соседей» слева и справа.

 

Строки

1. Дана строка. Напечатать входящие в нее слова, но в обратном порядке (сначала последнее, потом предпоследнее и т.д.).

2. Дана строка. Напечатать те слова этой строки, которые отличны от последнего слова и выполняется условие: в слове гласные буквы а, е, i, о, u чередуются с согласными.

3. Вводится строка. Если она является записью римского числа, то преобразовать ее в целое число.

4. Вводится 10 произвольных имен. Необходимо распечатать их в алфавитном порядке.

Замечание

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

5. Напишите функцию RightPosition(str1, str2: string), которая получает два параметра str1 и str2 типа string и возвращает позицию начала последнего появления str2 в str1. Например, RightPosition('Миссисипи', 'си') вернет значение 6.

6. Напишите функцию CountStr(str1, str2: string) которая получает два параметра str1 и str2 типа string и возвращает число, указывающее, сколько раз str2 встречается в str1. Функция не должна изменять свои параметры. Кроме того, любая литера в str1 может учитываться не более чем в одном вхождении str2. Например, CountStr('балалайка', 'ала') должна возвращать 1, а не 2.

7. Напишите функцию NonAlpha(str: string), которая получает параметр str типа string и возвращает позицию его первой литеры, не являющейся буквой (как латинского, так и русского алфавитов) строчной или прописной. Например, NonAlpha( 'stev7n' ) дает 5.

8. Напишите функцию Splite(name: string; var first, last : string), которая из параметра name, хранящего имя и фамилию человека, извлекает их в first (имя) и last (фамилия). Имя и фамилия разделены некоторым числом пробелов. Например, после обращения Splite('Вася Иванов', str1, str2) в str1 должно оказаться 'Вася', а в str2 'Иванов'. Необходимо также предусмотреть обнаружение и обработку некорректных данных. В частности, если в name вообще не окажется ни одного пробела, процедура должна установить в обоих выходных параметрах специальное значение 'error' (ошибка). Какие еще ошибочные ситуации следует учесть?

9. Пусть даны две строки str1 и str2. Необходимо выяснить, можно ли из str1 путём перестановки литер получить строку str2. Напишите подпрограмму, которая решала бы указанную задачу.

10. Напишите процедуру SortMid, которая сортировала бы ряд из n строк в алфавитном порядке, основываясь на k–ой литере каждой строки, где k является параметром, передаваемым процедуре SortMid. Например, если k=3, то элементы ряда должны быть отсортированы по возрастанию значения в третьей литере каждой строки. Если длина строки меньше k, то будем предполагать, что его k–ой литерой, реально не существующей, служит пробел.

11. Напишите процедуру сортировки строк в обратном алфавитном порядке.

12. Напишите подпрограммы Encode (зашифровать) и Decode (расшифровать), которые получают два параметра str и alpha типа string. В первом параметре задается слово, подлежащее шифрованию (расшифровке), второй представляет собой некоторую перестановку 26 латинских букв алфавита. Принцип преобразования для шифрации состоит в следующем. Если некоторая буква в str является k–ой буквой в обычном алфавите, то вместо нее должна быть взята буква из k–ой позиции "нового" алфавита alpha. Для подпрограммы дешифровки используется обратный принцип.

13. Расширим предыдущую задачу. Напишите программу для тестирования Encode и Decode. Она должна начинаться с ввода ключа для шифрования и дешифрации — 26–буквенной строки. Затем вводится серия строк, подлежащих обработке. Над каждой строкой применяется сначала операция шифрования, а затем дешифрации. При этом необходимо контролировать некоторые ошибочные ситуации. Например, каждая содержащаяся в ключе буква должна быть представлена только один раз.

14. Написать программу, которая будет вводить значения типа string и определять, является ли каждое из них правильным идентификатором, удовлетворяющем требованиям Паскаля. Напомним, вкратце правила построения имен. Всякое имя может содержать от 1 до 127 литер; первой литерой должна быть буква (строчная или прописная); любая другая литера (начиная со второй) может быть буквой, цифрой (от 0 до 9) или знаком подчеркивания. Если обнаружена ошибка, необходимо выдать сообщение, квалифицирующее ее.

15. Усовершенствуйте программу из предыдущей задачи, чтобы она умела распознавать служебные слова Паскаля и отвергать попытки их предъявления. Для простоты ограничьте набор служебных слов, взяв за основу только некоторые из них.

16. Усовершенствуйте программу из задачи 18, сделав возможным автоматическое преобразование неправильных идентификаторов в синтаксически допустимые. Если исходная строка имеет слишком большую длину, укоротите её до допустимого размера путем отбрасывания избыточных литер; если она пуста, добавьте букву 'x'. Если первая литера не является буквой, то вставьте перед ней 'x'. Если в строке присутствуют какие-то "незаконные" литеры, удалите их.

17. Задано десять русских имен. В тексте проверить, все ли эти имена написаны с большой буквы, если нет, то исправить.

18. Дана строка. Определить, стоят ли в данной строке подряд символы а и б.

19. Дана строка. Определить, есть ли в этой строке символы А и Е, а также количество каждого из этих символов.

20. Дана строка. Определить, сколько в ней знаков '+', и заменить их на '–'.

21. Дана строка. Определить, есть ли в ней все буквы, входящие в слово шина.

22. Дана строка. Определить, какие символы и сколько раз встречаются в данной строке.

23. В заданной строке установить пробелы вместо символов, номера позиций которых при делении на 4 дают в остатке 3.

24. Дана строка. Найти слова, которые имеют четную длину и начинаются с заданного символа.

25. Вывести строку длины N (N — четное), которая состоит из чередующихся символов C1 и C2, начиная с C1.

26. Дана строка. Вывести строку, содержащую те же символы, но расположенные в обратном порядке.

27. Дана строка. Вывести коды ее первого и последнего символа.

28. Дана строка. Подсчитать количество содержащихся в ней цифр1|прописных букв2|строчных букв3.

29. Дана строка. Преобразовать все строчные1|прописные2 латинские3|русские4 буквы в прописные1|строчные2.

30. Дана строка. Если она представляет собой запись целого числа, то вывести 1; если вещественного (с дробной частью), то вывести 2; если строку нельзя преобразовать в число, то вывести 0.

31. Дано целое число. Вывести набор символов, содержащий цифры этого числа в исходном1|обратном2 порядке.

32. Дана строка S, изображающая вещественное число в формате с плавающей точкой, и целое число N (N> 0). Вывести набор символов, изображающих первые N цифр дробной части этого вещественного числа (без округления).

33. Дана строка, изображающая целое число. Вывести сумму цифр этого числа.

34. Дана строка S и число N. Преобразовать строку S в строку длины N следующим образом: если длина строки S больше N, то отбросить первые символы, если длина строки S меньше N, то в ее начало добавить символы . (точка).

35. Даны два числа: N1 и N2, и две строки: S1 и S2. Получить из этих строк новую строку, объединив N1 первых символов строки S1 и N2 последних символов строки S2.

36. Даны две строки: S1 и S2. Проверить, содержится ли строка S2 в строке S1. Если да, то вывести номер позиции, начиная с которой S2 содержится в S1, если нет, то вывести 0.

37. Даны две строки: S1 и S2. Определить количество вхождений строки S2 в строку S1.

38. Дана строка S и символ C. Удвоить каждое вхождение символа C в строку S.

39. Даны строки S1, S2 и символ C. Перед1|после2 каждого вхождения символа C в строку S1 вставить строку S2.

40. Даны две строки: S1и S2. Удалить из строки S1 первую1| последнюю2| все3 подстроки, совпадающие с S2. Если таких подстрок нет, то вывести S1без изменений.

41. Даны три строки: S1, S2, S3. Заменить в строке S1 первое1| последнее2| все3 вхождения строки S2 на S3.

42. Дана строка. Вывести подстроку, расположенную между первой и второй1|последней2 точками исходной строки. Если в строке менее двух точек, то вывести всю исходную строку.

43. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Определить количество слов в строке.

44. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Определить количество слов, которые [начинаются и заканчиваются одной и той же буквой]1|[содержат хотя бы одну букву А]2.

45. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Определить количество слов, которые содержат ровно три буквы А .

46. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Определить длину самого короткого1|длинного2 слова.

47. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Вывести строку, содержащую эти же слова, но разделенные одним символом . (точка). В конце точку не ставить.

48. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Вывести строку, содержащую эти же слова (разделенные одним пробелом), но расположенные в обратном порядке.

49. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Преобразовать каждое слово в строке, удалив из него все последующие1|предыдущие2 вхождения первой1|последней2 буквы этого слова (количество пробелов между словами не изменять).

50. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Вывести строку, содержащую эти же слова (разделенные одним пробелом), но расположенные в алфавитном порядке.

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

52. Дана строка-предложение на русском языке. Подсчитать количество содержащихся в строке [знаков препинания]1|[гласных букв]2.

53. Дана строка-предложение на русском языке. Вывести самое короткое1|длинное2 слово в предложении (если таких слов несколько, то вывести первое3|последнее4 из них).

54. Дана строка-предложение, содержащая избыточные пробелы. Преобразовать ее так, чтобы между словами был ровно один пробел.

55. Дана строка, содержащая полное имя файла, то есть имя диска, список каталогов (путь), собственно имя и расширение. Выделить из этой строки имя1|расширение2 файла.

56. Дана строка, содержащая полное имя файла. Выделить из строки название последнего каталога (без символов \ ). Если файл содержится в корневом каталоге, то вывести символ \.

57. Дана строка-предложение на русском языке. Зашифровать ее, выполняя циклическую замену каждой буквы на следующую за ней в алфавите и сохраняя при этом регистр букв (А перейдет в Б , а — в б , Б — в В , я — в а и т.д.). Букву ё в алфавите не учитывать (е должна переходить в ж). Знаки препинания и пробелы не изменять.

58. Дана строка-предложение на русском языке и число k (0 < k < 10). Зашифровать строку, выполнив циклическую замену каждой буквы на букву того же регистра, расположенную в алфавите на kй позиции после шифруемой буквы (например, для k = 2 А перейдет в В , а — в в , Б — в Г , я — в б и т.д.). Букву ё в алфавите не учитывать, знаки препинания и пробелы не изменять.

59. Дано зашифрованное предложение на русском языке (способ шифрования описан в задании 41) и кодовое смещение k (0 < k < 10). Расшифровать предложение.

60. Дано зашифрованное предложение на русском языке (способ шифрования описан в задании 41) и его расшифрованный первый символ C. Определить кодовое смещение k и расшифровать предложение.

61. Дана строка-предложение. Зашифровать ее, поместив вначале все символы, расположенные на четных местах, а затем, в обратном порядке, все символы, расположенные на нечетных местах (например, строка Программа превратится в ргамамроП ).

62. Дано предложение, зашифрованное по правилу, описанному в предыдущем задании. Расшифровать это предложение.

63. Дана строка, содержащая несколько круглых скобок. Если скобки расставлены правильно (то есть каждой открывающей соответствует одна закрывающая), то вывести число 0. В противном случае вывести или номер позиции, в которой расположена первая ошибочная закрывающая скобка, или, если закрывающих скобок не хватает, число –1.

64. Дана строка, содержащая комментарии типа {...}. Создать другую строку, содержащую тот же текст, но без комментариев.

65. Дана строка, состоящая из русских слов, разделенных пробелами (одним или несколькими). Определить, сколько слов в строке являются палиндромами (перевертышами), и вывести эти слова.

66. Дана строка, содержащая некоторый текст. Определить, является ли данный текст палиндромом, т.е. читается ли он слева направо так же, как и справа налево (например: А роза упала на лапу Азора).

67. Дана строка, состоящая из латинских букв, в которой слова разделены пробелами (одним или несколькими). Напечатать те слова строки, которые отличны от последнего слова и удовлетворяют следующему свойству:

a) слово симметрично;

b) первая буква слова входит в него еще раз;

c) слово совпадает с начальным отрезком латинского алфавита (a, ab, abc и т.д.);

d) слово совпадает с конечным отрезком латинского алфавита (z, yz, xyz и т.д.);

e) длина слова максимальна;

f) в слове нет повторяющихся букв;

g) каждая буква входит в слово не менее двух раз;

h) в слове гласные буквы (a, e, i, o, u) чередуются с согласными.

68. Дана строка, ограниченная точкой, в которой слова разделены пробелом. Напечатать все слова, отличные от последнего слова, предварительно преобразовав каждое из них по следующему правилу:

a) перенести первую букву в конец слова;

b) перенести последнюю букву в начало слова;

c) удалить из слова первую букву;

d) удалить из слова последнюю букву;

e) удалить из слова все последующие вхождения первой буквы;

f) удалить из слова все предыдущие вхождения последней буквы;

g) оставить в слове только первые вхождения каждой буквы;

h) если слово нечетной длины, то удалить его среднюю букву.

 

Входные строковые параметры, если они не изменяются в теле процедуры/функции, для экономии памяти рекомендуется описывать как параметры-константы.

69. Описать функцию IsIdent(S) целого типа, проверяющую, является ли строка S допустимым идентификатором Паскаля. При утвердительном ответе возвращается 0. Если S является пустой строкой, то возвращается –1, если строка начинается с цифры, то возвращается –2. Если S содержит недопустимые символы, то возвращается номер первого недопустимого символа.

70. Описать функцию FillStr(S, Len) строкового типа, возвращающую строку длины Len, заполненную повторяющимися копиями строки-шаблона S (последняя копия строки-шаблона может входить в результирующую строку частично).

71. Описать процедуру UpCase(S)1|LowCase(S)2, преобразующую все строчные1|прописные2 буквы строки S в прописные1|строчные2 (остальные символы строки S не изменяются).

72. Описать процедуру TrimL(S)1|TrimR(S)2|Trim(S)3, удаляющую в строке S начальные1|конечные2|[начальные и конечные]3 пробелы.

73. Описать функцию PosLast(subS, S) целого типа, возвращающую номер позиции, с которой в строке S содержится последнее вхождение подстроки subS. Если в строке S отсутствуют подстроки subS, то функция возвращает 0.

74. Описать функцию PosK(subS, S, k) целого типа, возвращающую номер позиции, с которой в строке S содержится k-е вхождение подстроки subS (k > 0). Если количество вхождений subS в строке S меньше k, то функция возвращает 0.

75. Описать функцию WordN(S, k) строкового типа, возвращающую kе слово строки S (под словом понимается набор символов, не содержащий пробелов и ограниченный пробелами или началом/концом строки). Если количество слов в строке меньше k, то функция возвращает пустую строку. Используя эту функцию, выделить из данной строки S слова с номерами k1, k3, k3.

76. Описать процедуру SplitStr(S, W, N), которая формирует по данной строке S набор слов W, входящих в S (W — выходной строковый массив; N — его размер; предполагается, что N не будет превышать 10). Под словом понимается набор символов, не содержащий пробелов и ограниченный пробелами или началом/концом строки. Используя эту функцию, вывести количество слов N, содержащихся в данной строке S, и сами эти слова.

 

Одномерные массивы

1. Даны действительные числа x1, x2, ... , xn, y1, y2, ... , yn, r1, r2, ... , rn. Выяснить, есть ли на плоскости точка, принадлежащая всем кругам с1, с2, ... , сn, где ci имеет центр с координатами xi, yi и радиус ri.

2. Даны действительные числа a1, a2, ... , a2n. Эти точки определяют n интервалов числовой оси (a1, a2), (a3, a4), ..., (a2n-1, a2n). Является ли интервалом объединение этих интервалов? Если да, то указать концы этого интервала.

3. Даны действительные числа a1, a2, ... , a2n. Эти точки определяют n интервалов числовой (a1, a2), (a3, a4), ..., (a2n-1, a2n). Имеются ли точки числовой оси, принадлежащие по крайней мере трем каким-нибудь из данных интервалов. Если да, то указать какую-нибудь из этих точек.

4. Даны целые числа a1, a2, ..., an. Пусть M — наибольшее, m — наименьшее из них. Получить в порядке возрастания все целые числа из интервала (m, M), которые не входят в последовательность a1, a2, ..., an.

5. Даны координаты центров n окружностей и их радиусы. Определить число пересекающихся окружностей.

6. Все отрицательные элементы массива X перенести в его начало, а все остальные — в конец, сохраняя исходное взаимное расположение как среди отрицательных, так и среди остальных элементов. Дополнительный массив не заводить.

7. Переменной t присвоить значение true, если в массиве нет нулевых элементов и при этом положительные элементы чередуются с отрицательными и значение false в противном случае.

8. Имеются десять гирь весом a1, a2, ..., a10. Обозначим через ck — число способов, которыми можно составить вес k, то есть ck — это число решений уравнения a1x1 + a2x2 +...+ a10x10 = k, где xi может принимать значения 0 или 1 (i=1,..., 10). Получить с0, с1, ..., с10.

9. Прямая на плоскости может быть задана уравнением ax + by = c, где a, b одновременно не равны нулю, a, b, c — целые. Пусть даны коэффициенты нескольких прямых a1, b1, c1, a2, b2, c2, ..., an, bn, cn. Определить, имеются ли среди этих прямых совпадающие или параллельные.

10. Прямая на плоскости может быть задана уравнением ax + by = c, где a, b одновременно не равны нулю, a, b, c — целые. Пусть даны коэффициенты нескольких прямых a1, b1, c1, a2, b2, c2, ..., an, bn, cn. Определить, имеются ли среди этих прямых три прямые, пересекающиеся в одной точке.

11. Даны две последовательности по n чисел в каждой. Найти наименьшее среди тех чисел первой последовательности, которые не входят во вторую (считать, что хотя бы одно такое число есть).

12. Даны натуральное число n, целые числа a, x1, x2, ..., xn. Если в последовательности x1, x2, ..., xn есть хотя бы один член, равный a, то получить сумму всех членов, следующих за первым таким членом, иначе найти минимальный среди нечетных чисел последовательности x1, x2, ..., xn.

13. Даны целые числа a1, a2, ..., an, среди которых могут быть повторяющиеся. Составить новый массив из чисел, которые входят в последовательность по одному разу.

14. Даны целые числа a1, a2, ..., an, среди которых могут быть повторяющиеся. Составить новый массив из чисел, взятых по одному из каждой группы равных членов данной последовательности.

15. Даны натуральные числа k, n, действительные числа a1, a2, ..., akn. Получить последовательность min(a1, a2, ..., ak), min(ak+1, ak+2, ..., a2k), ..., min(ak(n-1)+1, ..., akn).

16. Даны натуральные числа k, n, действительные числа a1, a2, ..., akn. Получить последовательность последовательность max(a1, a2, ..., ak), max (ak+1, ak+2, ..., a2k), ..., max (ak(n-1)+1, ..., akn).

17. Даны натуральные числа k, n, действительные числа a1, a2, ..., akn. Получить min(a1 + a2 + ... + ak, ak+1 + ak+2 + ... + a2k, ..., ak(n-1)+1 + ... + akn).

18. Сформировать одномерный массив размера N по следующему принципу: четные элементы равны квадрату индекса, а нечетные его обратной величине.

19. Заполнить одномерный массив размера N так, чтобы каждый элемент с четным индексом был равен половине своего номера, а каждый элемент с нечетным индексом — 0.

20. Даны два массива А(N) и В(N).Сформировать С(N) такой, что С[i]=А[i]/B[i], если i нечетное, и C[i]=A[i]*B[i], если i четное.

21. Дан массив размера N. Вывести его элементы в обратном порядке.

22. Подсчитать сумму элементов одномерного массива.

23. Подсчитать сумму элементов двухмерного массива.

24. Найти максимальный элемент в массиве. Найти индекс максимального элемента.

25. Найти минимальный элемент в массиве. Найти индекс минимального элемента.

26. Поменять местами минимальный и максимальный элементы массива.

27. Найти среднее арифметическое элементов массива.

28. Вывести всех элементов массива из интервала C..D.

29. Массив размера N заполнен случайными числами от –15 до 15.Определить количество отрицательных элементов и их индексы.

30. Дан массив размера N. Осуществить циклический сдвиг элементов массива влево (вправо) на одну позицию.

31. Дан массив размера N и число k (0 < k < 5, k < N). Осуществить циклический сдвиг элементов массива влево (вправо) на k позиций.

32. Вывести наиболее часто встречающийся элемент массива.

33. Проверить, все ли элементы массива различны.

34. Проверить, имеется ли в массиве размера N. хотя бы одна пара чисел, совпадающих по величине.

35. Дан массив размера N. Определить индексы всех равных элементов.

36. Дан массив размера N. Вывести вначале его элементы с четными (нечетными) индексами, а затем — с нечетными (четными).

37. Дан целочисленный массив A размера N. Вывести номер первого (последнего) из тех его элементов A[i], которые удовлетворяют двойному неравенству: A[1] < A[i] < A[N]. Если таких элементов нет, то вывести 0.

38. Дан целочисленный массив A размера N и два числа x и y (x < y). Найти номера элементов, удовлетворяющих условию x< A[i] < y.

39. Дан целочисленный массив размера N. Преобразовать его, прибавив к четным (нечетным) числам первый (последний) элемент. Первый и последний элементы массива не изменять.

40. Дан целочисленный массив размера N. Вывести вначале все его четные (нечетные) элементы, а затем — нечетные (четные).

41. Дан целочисленный массив размера N. Изменить знак всех элементов с четными индексами на противоположный.

42. Дан целочисленный массив размера N. Заменить нулевые элементы квадратами их индексов.

43. Дан целочисленный массив размера N. Поменять местами соседние четные и нечетные по номеру элементы. Указание: дополнительные массивы не использовать.

44. Заменить все положительные (отрицательные) элементы целочисленного массива на значение минимального (|максимального).

45. Дан массив размера N. Переставить в обратном порядке элементы массива, расположенные между его минимальным и максимальным элементами.

46. Проверить, образуют ли элементы целочисленного массива размера N арифметическую прогрессию. Если да, то вывести разность прогрессии, если нет — вывести 0.

47. Проверить, образуют ли элементы целочисленного массива размера N геометрическую прогрессию. Если да, то вывести знаменатель прогрессии, если нет — вывести 0.

48. Дан массив ненулевых целых чисел размера N. Проверить, чередуются ли в нем четные и нечетные числа. Если чередуются, то вывести 0, если нет, то вывести номер первого элемента, нарушающего закономерность.

49. Дан массив ненулевых целых чисел размера N. Проверить, чередуются ли в нем положительные и отрицательные числа. Если чередуются, то вывести 0, если нет, то вывести номер первого элемента, нарушающего закономерность.

50. Дан массив ненулевых целых чисел размера N. Определить число соседств из двух чисел разного знака.

51. Дан массив размера N. Вычислить сумму произведений всех пар соседних чисел.

52. Дан массив размера N. Вычислить сумму произведений всех троек соседних чисел.

53. Дан массив размера N. Определить количество пар соседних чисел, являющихся противоположными.

54. Дан массив размера N. Определить произведение нечетных элементов, имеющих четные индексы.

55. Дан массив размера N. Найти количество его локальных минимумов.

56. Дан массив размера N. Найти количество его локальных максимумов.

57. Дан массив размера N. Найти максимальный из его локальных минимумов.

58. Дан массив размера N. Найти минимальный из его локальных максимумов.

59. Дан массив размера N. Определить количество участков, на которых его элементы монотонно возрастают.

60. Дан массив размера N. Определить количество участков, на которых его элементы монотонно убывают.

61. Дан массив размера N. Определить количество его промежутков монотонности (то есть участков, на которых его элементы возрастают или убывают).

62. Дано вещественное число R и массив размера N. Найти элемент массива, который наиболее близок к данному числу.

63. Дано вещественное число R и массив размера N. Найти элемент массива, который наименее близок к данному числу.

64. Дано вещественное число R и массив размера N. Найти два элемента массива, сумма которых наиболее близка к данному числу.

65. Дано вещественное число R и массив размера N. Найти два элемента массива, сумма которых наименее близка к данному числу.

66. Дан массив размера N. Найти номера двух ближайших чисел из этого массива.

67. Дан целочисленный массив размера N. Определить максимальное количество его одинаковых элементов.

68. Дан целочисленный массив размера N. Удалить из массива все элементы, встречающиеся менее двух раз.

69. Дан целочисленный массив размера N. Удалить из массива все элементы, встречающиеся более двух раз.

70. Дан целочисленный массив размера N. Удалить из массива все элементы, встречающиеся ровно два раза.

71. Дан целочисленный массив размера N. Удалить из массива все элементы, встречающиеся ровно три раза.

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

73. Дан целочисленный массив размера N, содержащий большое количество нулевых элементов. Заменить группы элементов, состоящие из нечетного количества нулей, на один нулевой элемент, а из четного — на два.

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

75. Дан целочисленный массив размера N. Если он является перестановкой, то есть содержит все числа от 1 до N, то вывести 0, в противном случае вывести номер первого недопустимого элемента.

76. Дан массив размера N. Преобразовать его, вставив перед1|после2 каждого положительного3|