ベリラボ

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

ベリサイン + apahce + OpenSSL + mod_ssl ではまり

ベリサイン + apahce + OpenSSL + mod_ssl ではまりました。 秘密鍵作成、CSR作成を行ってベリサインに申請。 戻ってきたServerIDを保存して以下のようにssl.con …

no image

LWP::UserAgent で、cookie 保存

Perl LWP::UserAgent で、cookie を保存するサンプルプログラムをwikiに掲載しました。 Perl 5.8.8 上で確認しています。 サンプルプログラム

no image

オバマ氏大統領就任演説

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

no image

Linux(UNIX)であるディレクトリ配下の全ファイルから検索

あるディレクトリにファイルが複数あって検索するとき、grepコマンドで検索できますが、サブディレクトリがあって階層も不明な場合、どうしたらよいでしょうか? こんなとき、Linuxであれば、以下のように …

no image

リスとコーヒーとイルカを買った 犬

巨人も真っ青、犬が買うとは思わなかった。 【続報】OracleのSun買収で最高の統合ソリューションを – エリソン氏 | 経営 | マイコミジャーナル. Solaris・・・・・Linu …