2 Commits

3 changed files with 33 additions and 54 deletions

View File

@@ -8,5 +8,5 @@ read num1
echo "Введите второе число:" echo "Введите второе число:"
read num2 read num2
# Вызываем скрипт НОК и передаем ему числа # Вызываем скрипт НОД и передаем ему числа
./script_nok.sh $num1 $num2 ./script_nod.sh $num1 $num2

31
script_nod.sh Executable file
View File

@@ -0,0 +1,31 @@
#!/bin/bash
# Проверка количества аргументов
if [ $# -ne 2 ]; then
echo "Использование: $0 <число1> <число2>"
exit 1
fi
# Проверка, что аргументы являются числами
if ! [[ "$1" =~ ^[0-9]+$ ]] || ! [[ "$2" =~ ^[0-9]+$ ]]; then
echo "Ошибка: аргументы должны быть целыми неотрицательными числами"
exit 1
fi
# Функция для нахождения НОД алгоритмом Евклида
gcd() {
local a=$1
local b=$2
while [ $b -ne 0 ]; do
local temp=$b
b=$((a % b))
a=$temp
done
echo $a
}
# Вычисление НОД
result=$(gcd $1 $2)
echo $result

View File

@@ -1,52 +0,0 @@
#!/bin/bash
# Функция для нахождения наибольшего общего делителя (НОД) с помощью алгоритма Евклида
gcd() {
local a=$1
local b=$2
while [ $b -ne 0 ]; do
local temp=$b
b=$((a % b))
a=$temp
done
echo $a
}
# Функция для нахождения наименьшего общего кратного (НОК)
lcm() {
local a=$1
local b=$2
# Проверка на ноль
if [ $a -eq 0 ] || [ $b -eq 0 ]; then
echo 0
return
fi
# Берем абсолютные значения
a=${a#-}
b=${b#-}
local gcd_value=$(gcd $a $b)
echo $((a * b / gcd_value))
}
# Основная часть скрипта
if [ $# -ne 2 ]; then
echo "Использование: $0 <число1> <число2>"
echo "Пример: $0 12 18"
exit 1
fi
# Проверка, что аргументы являются числами
if ! [[ $1 =~ ^-?[0-9]+$ ]] || ! [[ $2 =~ ^-?[0-9]+$ ]]; then
echo "Ошибка: Аргументы должны быть целыми числами"
exit 1
fi
# Вычисление НОК
result=$(lcm $1 $2)
echo "Наименьшее общее кратное (НОК) чисел $1 и $2 = $result"