また,実行速度はプログラマの質による差異が.速いプログラムと遅いプロ グラムでは、100倍、1000倍速度が違うことは珍しくない。このような速度の 差は,使用するプログラミング言語の違いにより生じることもあるが,あるこ とをやる際のアルゴリズム(計算法)による違いによる場合が多い.
ここでは,全順序関係の成り立つ要素を順序関係に従って整列しなおす(これ をソートと呼ぶ)プログラムを例に,アルゴリズムと実行速度の関係について, 学ぶことにする.
% java Catと実行すると,キーボードから入力して画面上に出力するプログラムになるが (終了はCtrl-dでおこなう),
% java Cat < Cp.java > tmpと実行するとCat.javaから読み込んだファイルを tmpに
 // BufferedReaderなどを使うので,java.io.*を import する.
import java.io.*;
class Cat {
   // 入出力の途中で,IOExceptionの例外が起きる可能性があるので,
   // throws IOException をつける.
  public static void main(String [] args) throws IOException{
    BufferedReader is=new BufferedReader(new InputStreamReader(System.in));
    String s;
    while((s=is.readLine())!=null){
      System.out.println(s);
    }
  }
}
入力用のストリームは,FileReaderから BufferedReaderを作ることにより,行単位の入出力をおこなうことができ る.出力用のストリームはFileWriterから PrintWriterを作ることにより,println等が実行できる.
これを使った Cpプログラムを見てみる.
 // BufferedReaderなどを使うので,java.io.*を import する.
import java.io.*;
class Cp {
   // 入出力の途中で,IOExceptionの例外が起きる可能性があるので,
   // throws IOException をつける.
  public static void main(String [] args) throws IOException{
    if(args.length!=2) usage();
    BufferedReader is=new BufferedReader(new FileReader(args[0]));
    PrintWriter ps=new PrintWriter(new FileWriter(args[1]));
    String s;
    while((s=is.readLine())!=null){
      ps.println(s);
    }
    is.close();
    ps.close();
  }
  static void usage(){
    System.err.println("使い方: java Cp コピー元のファイル コピー先のファイル");
    System.exit(1);
  }
}
不要になったストリームを close するのを忘れないように.
java Cp Cp.java sokoを実行すると Cp.javaの内容が sokoというファイルにコピーされる.
% man sortで確認できると思う.ここでは,その最も単純な行の先頭からの辞書順序での ソートをおこなうプログラムを扱ってみる.
まずは準備として,ファイルから読み込んで1行毎の文字列の配列を作成する という部分を見てみる.
 // BufferedReaderなどを使うので,java.io.*を import する.
import java.io.*;
 // Vectorを使うので java.util.* を importする.
import java.util.*;
class SortTest {
    // このメソッドの中で linesの並び替えをおこなう.
  static void sort(String[] lines){
  }
  //  IOExceptionを catchしていないので,throws IOExceptionをつける.
  public static void main(String args[]) throws IOException{
    // ファイル名と思って BufferedReader
    BufferedReader is=new BufferedReader(new FileReader(args[0]));
    // 何行になるかわからないので,Vectorで記憶しておく
    Vector v=new Vector();
    String s;
    // 1行読み込んでファイルの終端に到達しない間
    while((s=is.readLine())!=null){
      // Vectorの最後に要素を加える
      v.addElement(s);
    }
    // 入力ストリームを閉じる
    is.close();
    // Vectorから配列に変換するために,領域を確保する
    String[] lines=new String[v.size()];
    // Vectorから配列に変換する.
    v.copyInto(lines);
    // ソートする
    sort(lines);
    // ソートした結果を出力する.
    for(int i=0;i< lines.length;i++)
      System.out.println(lines[i]);
  }
}