プログラム中で同じ処理を何度も行いたい場合がよくある.そのたびごとに同
じプログラムを何度も書くのは馬鹿げている.同じ処理はサブルーチンとして
別のユニットにしておくと都合がよい.
主プログラムと独立に次のように書く. subroutine文以下endまでがサブルーチンである.
c main program
implicit none
real*8 d(10),f,g
......
call S(f,g,d)
......
end
subroutine S(a,b,c)
implicit none
real*8 a,b,c(10)
......
......
return
end
サブルーチン文 |
S(a,b,c) |
サブルーチンの定義をおこなう |
S |
サブルーチン名:英文字で始まる6文字以内の英数字 |
a,b,c |
仮引数:使う変数は型宣言すること |
call 文 |
call S(f,g,d) |
サブルーチンを呼び出す |
f,g,d |
実引数:仮引数と順序, 型を一致させる必要あり |
サブルーチンはend文で終わらなければならない.サブルーチンから主プログラムに戻る場所では
return
を書く.return文は何個あってもよい(endは一個:end文のみでreturn文がない場合はendで呼ばれた場所に戻る).それでは次のプログラム
を入力して実行してみよう.
プログラム1
c main program
implicit none
real*8 a,b,c
a=1.D0
b=2.D0
call wa(a,b,c)
write(6,*) c
end
c subroutine
subroutine wa(a,b,c)
real*8 a,b,c
c=a+b
return
end
呼ぶ方(call wa(a,b))と呼ばれる方(subroutine wa(a,b))の引数は順序,個数,型を一致させなければならない.逆に言うと,引数の個数,型が一致していれば名前は違っていてもよい.サブルーチンを使う場合は, サブルーチンとの変数, 配列のやりとりに注意すること.
どれが入力でどれが出力かを頭にいれてプログラムを作成すること.
次のプログラムは何をするのか考えてみよう.
プログラム2
c main program
implicit none
real*8 a,b,c,d,e
a=1.D0
b=2.D0
d=3.D0
e=4.D0
call wa(a,b,c)
write(6,*) c
call wa(d,e,c)
write(6,*) c
end
subroutine wa(a,b,c)
real*8 a,b,c
c=a+b
return
end
練習問題1
以下のプログラムを正しく修正せよ.
c 1-1
implicit none
real*8 a,b
a=1.D0
b=2.D0
call wa(a,b)
write(6,*) b
end
subroutine wa(a,b,c)
real*8 a,b
b=a+b
return
end
c 1-2
implicit none
real*8 a,b
a=1.D0
b=2.D0
call wa(a,b)
write(6,*) b
end
subroutine wa(a,b)
integer a,b
b=a+b
return
end
c 1-3
implicit none
real*8 a(2),b
a(1)=1.D0
a(2)=2.D0
b=0.D0
call wa(a,b)
write(6,*) b
end
subroutine wa(a,b)
real*8 a,b
b=a(1)+a(2)
return
end
練習問題2
プログラム1-2を正しく変更したものをさらに修正した上で, 二つの数の積を計算するサブルーチンを書き加えよ. これを用いて変数a,bの積(答えは2.D0)を算出せよ.
練習問題3
先週の問題(大きい順に並び変えるプログラム)をサブルーチンを用いて改造せよ. データ読みとり部(subroutine input(m); mはデータを格納した配列), 入れ換え部(subroutine sort(m)), 出力部(subroutine output(m))と三つのサブルーチンに分割せよ. それぞれの役割がわかるようにコメント文を挿入しておくこと.
練習問題4
1) n!を計算するサブルーチン subroutine fact(n,ans)(ansは答えの整数)を作成せよ.
2) n個のものからm個のものを取り出す組み合わせの数 nCmを計算するサブルーチン subroutine comb(n,m,ans) を作成せよ.
3) 二項定理によると,f=(x+y)**nは
(x+y)**n=ΣnCm x**(n-m)y**m
となる.二つのサブルーチンを用いてfを計算するプログラムを作成せよ.x=0.3,y=0.7,n=10として実行し,結果が1.0になることを確かめよ.