
#!/bin/bash
sed 's/[^0-9 ]*//g' $1 | tr " " "\n" > outfile.txt
sed '/^\s*$/d' outfile.txt > outfile1.txt
if [ $2 == "-s" ] || [ $2 == "-si" ] || [ $2 == "-is" ]
then
sum=0;
while read num;
do ((sum += num));
done < outfile1.txt;
echo "SUMA= $sum"
fi
if [ $2 == "-i" ] || [ $2 == "-si" ] || [ $2 == "-is" ]
then
ilo=1;
while read num1;
do((ilo = num1 * ilo));
echo $num1
done < outfile1.txt;
echo "ILOCZYN= $ilo"
fi
это мой скрипт и это файл 1-го аргумента
1 2 3 4 5 4 3 2 3 4 5 4 3
2 2 2 2 22 3 34 4 4 5 5 5 d
3 43 54 5 3
Вот что я получаю из скрипта, когда хочу получить произведение всех чисел и их сумму.
s17545@msh:~$ ./skrypt12.sh logfile.txt -si
SUMA= 241
1
.
. all of the numbers in outfile1.txt
.
3
ILOCZYN= -2888071394797551616
есть идеи, что я делаю не так?
решение1
Какстраница ссылка от @steeldriverобъясняет, арифметическое переполнение — это факт жизни в Bash. Вместо этого вы могли бы:
- используйте язык, который изначально поддерживает числа произвольного размера, например (я полагаю) Haskell, Lisp или Scheme,
- используйте язык, который выдает исключение при арифметическом переполнении, например Java или Rust,
- проверьте, уменьшилось ли произведение после каждой операции (так как все ваши числа положительны), или
- переосмыслите свой подход, чтобы вам не приходилось умножать все числа за один раз (что, конечно, не всегда возможно).