2014年3月16日日曜日

開発環境

C++実践プログラミング (スティーブ オウアルライン (著)、Steve Oualline (原著)、Steve Oualline(原著)、望月 康司(翻訳)、クイープ(翻訳) 、オライリー・ジャパン)のⅢ部(高度な型とクラス)の13章(シンプルなクラス)、13.9(プログラミング実習)、実習 13-4.を解いてみる。

その他参考書籍

実習 13-4.

コード(BBEdit, Emacs)

sample233_4.cpp

#include <iostream>
#include <assert.h>

class small_set {
private:
  int count;
  int data[32];
public:
  explicit small_set();
  // small_set(const small_set& old_small_set)
  // ~small_set)
  // operator = (const small_set& old_small_set)
  void set(int item);
  void clear(int item);
  int test(int item);
  void p();
};

inline small_set::small_set()
{
  count = 0;
  int i;
  for (i = 0; i < 32; ++i) {
    data[i] = -1;
  }
}

inline void small_set::set(int item)
{
  assert(item >= 0 && item < 32);

  if (!test(item)) {
    data[count] = item;
    ++count;
  }
}

inline void small_set::clear(int item)
{
  if (test(item)) {
    int i;
    for (i = 0; i < count; ++i)
      if (data[i] == item) {
        if (i == count - 1)
          data[i] = -1;
        else
          while (data[i] != -1) {
            data[i] = data[i - 1];
            ++i;
          }
        --count;
        break;
      }
  }
}

inline int small_set::test(int item)
{
  int i;

  for (i = 0; i < count; ++i)
    if (data[i] == item)
      return 1;
  return 0;
}

inline void small_set::p()
{
  int i;
  for (i = 0; i < count; ++i)
    std::cout << data[i] << ' ';
  std::cout << '\n';
}

int main()
{
  small_set a_set;

  a_set.set(3);
  a_set.p();
  a_set.set(5);
  a_set.p();
  a_set.set(5);
  a_set.p();

  std::cout << a_set.test(3) << '\n';
  std::cout << a_set.test(0) << '\n';

  a_set.clear(5);
  a_set.p();

  return (0);
}

Makefile

#
# FSFのg++コンパイラ用のMakefile
#
CC=g++
CFLAGS=-g -Wall
all: sample233_4

sample233_4: sample233_4.cpp
 ${CC} ${CFLAGS} -o sample233_4 sample233_4.cpp

clean:
 rm sample233_4

入出力結果(Terminal)

$ make && ./sample233_4
g++ -g -Wall -o sample233_4 sample233_4.cpp
3 
3 5 
3 5 
1
0
3 
$

0 コメント:

コメントを投稿