ベリラボ

OSS(オープンソースソフトウェア) を主体とした技術検証と小ネタなど

その他

よいプログラム書くために

投稿日:

よいプログラム書くためには、どうすればいいか? を簡単に書きます。

「1から10までの和を求めるプログラムを書け」 という命題にどう書くでしょう。
プログラムを習いたての人に依頼すると、perlだと以下のようなプログラムも多く見かけます。

#!/usr/bin/perl

use strict;

my $n=10;

my $s=0;
for(my $i=1;$i< =$n;$i++) {
$s+=$i;
}

print “s=”,$s,”\n”;

このプログラムで間違いはありません。
でも、このように書くとnが少ない数であればよいのですが、数万や数億のオーダーになった場合や和を求めるだけでなく、多数の項目の平均などを求めようとした場合、ぐっと遅くなってきます。

プログラム上級者であれば、以下のようになります。

#!/usr/bin/perl

use strict;

my $n=10;

my $s=(1+$n)*$n/2;

print “s=”,$s,”\n”;

このように和の公式を使ってnの値によって実行速度に違いがないようにします。

要するに、よいプログラムを書くためには、perlやPHP、Javaなどの言語を学習するだけでは、上達しないということです。色々な知識を学んだ結果としてよいプログラムを書けるようになります。
プログラムを習いたての人は、色々な知識も学習するとよいですよ。

-その他

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

関連記事

no image

Linux(UNIX)でファイルやディレクトリの権限変更

Linux(UNIX)でファイルやディレクトリの権限変更をするとき、chmodコマンドを使います。なぜかわかりませんが 「chmod 755 ファイル名」 とモードに数値を使っている場面を多く見かけま …

no image

fetchmail + procmail でメール転送

どこかのメールサーバに届いたメールをなにも考えず全部別のメールサーバに転送したい場合の設定をgoogle、Technoratiで検索したらなかなかみつからなかったのでまとめてみました。 .forwar …

no image

オバマ氏大統領就任演説

バラク・オバマ氏の大統領就任演説を見ました。 深夜2時からテレビ放映だったのですが、私が生きている間には、これ程の出来事をリアルに見ることができないかもしれないという想いで眠い眼をこすりながら演説だけ …

no image

Gmailのデータバックアップ

Gmailにメモや雑多なデータを置いていますが、ここのところのGoogleのサービス終了告知に不安となり、Gmailのデータをローカルマシンに取り込んでいます。(誤解のないように、Gmailがサービス …

no image

DNS(bind)の誤解

DNS(bind)で誤解していました。(汗) DNS(bind)で、tcpの53番ポートを使うのは、ゾーン情報の転送時のMaster/Slave間で行うのみと理解していました。 が、よくよく調べてみる …