1. 程式人生 > >從新手到系統管理員(四):Linux Shell指令碼程式設計之數學(Part I)

從新手到系統管理員(四):Linux Shell指令碼程式設計之數學(Part I)

本文由 [茶話匯] – [Qing] 編譯自 [Avishek Kumar] 轉載請註明出處

Shell-Scripting-Part-41

這部分主要討論數學相關的shell指令碼程式設計。

加法運算

新建一個檔案“Addition.sh”,輸入下面的內容並賦予其可執行的許可權。

[code language=”bash”]
#!/bin/bash
echo “Enter the First Number: ”
read a
echo “Enter the Second Number: ”
read b
x=$(expr "$a" + "$b")
echo $a + $b = $x
[/code]

輸出結果:

[code language=”bash”]
[

[email protected] ~]# vi Additions.sh
[[email protected] ~]# chmod 755 Additions.sh
[[email protected] ~]# ./Additions.sh

“Enter the First Number: ”
12
“Enter the Second Number: ”
13
12 + 13 = 25
[/code]

你可以從這裡下載這個例子的程式碼。

減法運算

[code language=”bash”]
#!/bin/bash
echo “Enter the First Number: ”
read a
echo “Enter the Second Number: ”
read b
x=$(($a – $b))
echo $a – $b = $x
[/code]

注意:這裡我們沒有像上面的例子中使用“expr”來執行數學運算。

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi Substraction.sh
[[email protected] ~]# chmod 755 Substraction.sh
[[email protected] ~]# ./Substraction.sh

“Enter the First Number: ”
13
“Enter the Second Number: ”
20
13 – 20 = -7
[/code]

你可以從這裡下載這個例子的程式碼。

乘法運算

[code language=”bash”]
#!/bin/bash
echo “Enter the First Number: ”
read a
echo “Enter the Second Number: ”
read b
echo "$a * $b = $(expr $a \* $b)"
[/code]

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi Multiplication.sh
[[email protected] ~]# chmod 755 Multiplication.sh
[[email protected] ~]# ./Multiplication.sh

“Enter the First Number: ”
11
“Enter the Second Number: ”
11
11 * 11 = 12
[/code]

你可以從這裡下載這個例子的程式碼

除法運算

[code language=”bash”]
#!/bin/bash
echo “Enter the First Number: ”
read a
echo “Enter the Second Number: ”
read b
echo "$a / $b = $(expr $a / $b)"
[/code]

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi Division.sh
[[email protected] ~]# chmod 755 Division.sh
[[email protected] ~]# ./Division.sh

“Enter the First Number: ”
12
“Enter the Second Number: ”
3
12 / 3 = 4
[/code]

你可以從這裡下載這個例子的程式碼

陣列

下面的這個指令碼可以列印一組數字。

[code language=”bash”]
#!/bin/bash
echo “Enter The Number upto which you want to Print Table: ”
read n
i=1
while [ $i -ne 10 ]
do
i=$(expr $i + 1)
table=$(expr $i \* $n)
echo $table
done
[/code]

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi Table.sh
[[email protected] ~]# chmod 755 Table.sh
[[email protected] ~]# ./Table.sh

“Enter The Number upto which you want to Print Table: ”
29
58
87
116
145
174
203
232
261
290
[/code]

你可以從這裡下載這個例子的程式碼

判斷奇偶數

[code language=”bash”]
#!/bin/bash
echo "Enter The Number"
read n
num=$(expr $n % 2)
if [ $num -eq 0 ]
then
echo "is a Even Number"
else
echo "is a Odd Number"
fi
[/code]

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi EvenOdd.sh
[[email protected] ~]# chmod 755 EvenOdd.sh
[[email protected] ~]# ./EvenOdd.sh

Enter The Number
12
is a Even Number
[/code]

[code language=”bash”]
[[email protected] ~]# ./EvenOdd.sh

Enter The Number
11
is a Odd Number
[/code]

你可以從這裡下載這個例子的程式碼

Factorial數

[code language=”bash”]
#!/bin/bash
echo "Enter The Number"
read a
fact=1
while [ $a -ne 0 ]
do
fact=$(expr $fact \* $a)
a=$(expr $a – 1)
done
echo $fact
[/code]

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi Factorial.sh
[[email protected] ~]# chmod 755 Factorial.sh
[[email protected] ~]# ./Factorial.sh

Enter The Number
12
479001600
[/code]

你可以從這裡下載這個例子的程式碼

判斷Armstrong數

Armstrong數:在三位的正整數中,例如abc,有一些可能滿足(a^3)+(b^3)+(c^3)=abc,即各個位數的立方和正好是該數的本身。這些數即稱為Armstrong數。

[code language=”bash”]
#!/bin/bash
echo "Enter A Number"
read n
arm=0
temp=$n
while [ $n -ne 0 ]
do
r=$(expr $n % 10)
arm=$(expr $arm + $r \* $r \* $r)
n=$(expr $n / 10)
done
echo $arm
if [ $arm -eq $temp ]
then
echo "Armstrong"
else
echo "Not Armstrong"
fi
[/code]

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi Armstrong.sh
[[email protected] ~]# chmod 755 Armstrong.sh
[[email protected] ~]# ./Armstrong.sh

Enter A Number
371
371
Armstrong
[/code]

[code language=”bash”]
[[email protected] ~]# ./Armstrong.sh

Enter A Number
123
36
Not Armstrong
[/code]

你可以從這裡下載這個例子的程式碼

判斷質數

[code language=”bash”]
#!/bin/bash
echo “Enter Any Number”
read n
i=1
c=1
while [ $i -le $n ]
do
i=$(expr $i + 1)
r=$(expr $n % $i)
if [ $r -eq 0 ]
then
c=$(expr $c + 1)
fi
done
if [ $c -eq 2 ]
then
echo “Prime”
else
echo “Not Prime”
fi
[/code]

輸出結果:

[code language=”bash”]
[[email protected] ~]# vi Prime.sh
[[email protected] ~]# chmod 755 Prime.sh
[[email protected] ~]# ./Prime.sh

“Enter Any Number”
12

“Not Prime”
[/code]

你可以從這裡下載這個例子的程式碼