Skip to content

Java Simple Calculation (課題のために作られた電卓プログラム)

Notifications You must be signed in to change notification settings

skytomo221/Q0-Calculator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Q0 Calculator

Q0 Calculator は Java の課題のために作られた電卓プログラムです。

実行方法

こちらから、Q0.zipファイルをダウンロードし、解凍して、Q0.jarをクリックしてください。

計算例

Input  => 1 + 2 * 3
Output => 7

Input  => (1 + 2) * 3
Output => 9

Input  => 1 ÷ 3
Output => 0.3333333333333333

Input  => 0.3333333333333333 × 3
Output => 1.0

Input  => -2 ^ 100
Output => -1267650600228229401496703205376

Input  => 0xff + 0o77 + 0b11
Output => 321

Input  => 1¬¬ + ¬
Output => 88

Input  => "aa" < "ab" < "ac"
Output => true

Input  => 5 > 4 > 33 > 2 > 1
Output => false

Input  => 'a' + 1
Output => 'b'

Input  => "abc" * "def"
Output => "abcdef"

Input  => "abc" ^ 5
Output => "abcabcabcabcabc"

Input  => z = begin
            x = 1
            y = 2
            x + y
          end
Output => 3

Input  => x = e^π
          y = π^e
          if x < y
              "x is less than y"
          elseif x > y
              "x is greater than y"
          else
              "x is equal to y"
          end
Output => "x is greater than y"

Input  => i = 1
          sum = 0
          while 1 <= i <= 10
            sum = sum + i
            i = i + 1
          end
          sum
Output => 55

型名 説明
Bool 真理値
Char 真理値
Int 整数型
Float 浮動小数点数型
String 文字列型

リテラル

リテラル 表記
0xff 16進数表記
0o77 8進数表記
0o11 2進数表記
1.0e10 Float64型指数表記
1.0f10 Float32型指数表記
¬ フ記法

演算子の優先順位

優先順位 演算子
9 ()
8 ^
7 * / & % % of
6 + - | $
5 == != <= < > >=
4 &&
3 ||
2 =
1 begin ... end if if else while

演算子

算術演算子

名称 説明
+x 単項加算演算子 符号を反転しないことを明示的に表します
-x 単項減算演算子 符号を反転します
x + y 加算演算子 加算演算子は2つの数値の和を返します。
x - y 減算演算子 減算演算子は 1 つの数値から 1 つの数値を差し引き、差を返します。
x * y 乗算演算子 乗算演算子は数値を掛けあわせた結果を返します。
x / y 除算演算子 除算演算子は左のオペランドを右のオペランドで割り引くことで商を返します。
x ^ y べき乗演算子 べき乗は 1 つ目の数値を 2 つ目の数値でべき乗した値を返します。
x % y 剰余演算子 剰余演算子は 1 つ目の数値を 2 つ目の数値で割った余りを返します。剰余は常に被除数の符号を採用します。

ビット演算子

名称 説明
x & y ビット積 オペランドの対応するビットがともに 1 である各ビットについて 1 を返します。
x | y ビット和 オペランドの対応するビットがどちらかまたはともに 1 である各ビットについて 1 を返します。

比較演算子

名称 説明
x == y 等価演算子 等価演算子は、オペランド同士が等しいならば、真を返します。
x != y 不等価演算子 不等価演算子は、オペランド同士が等しくないならば、真を返します。
x <= y 小なりイコール演算子 小なりイコール演算子は、左オペランドが右オペランド以下ならば、真を返します。
x < y 小なり演算子 小なり演算子は、左オペランドが右オペランドより小さければ、真を返します。
x >= y 大なりイコール演算子 大なりイコール演算子は、左オペランドが右オペランド以上ならば、真を返します。
x > y 大なり演算子 大なり演算子は、左オペランドが右オペランドより大きければ、真を返します。

論理演算子

名称 説明
x && y AND 演算子 AND 演算子は、左右のオペランドがどちらも真ならば、真を返します。
x || y OR 演算子 OR 演算子は、左右のオペランドがどちらかが真ならば、真を返します。

関数

説明
abs 絶対値を返します。
asin 指定された値の逆余弦(アーク・コサイン)を返します。返される角度の範囲は、 0.0 から π です。
atan 指定された値の逆正弦(アーク・サイン)を返します。返される角度の範囲は、 -π/2 から π/2 です。
cbrt 立方根を返します。
ceil 引数の値以上で、計算上の整数と等しい、最小の(負の無限大にもっとも近い) Float 値を返します。
cos 指定された角度の余弦(コサイン)を返します。
cosh Float 値の双曲線余弦を返します。
exp オイラー数 e を Float 値で累乗した値を返します。
expm1 e^x -1を返します。
floor 引数の値以下で、計算上の整数と等しい、最大の(正の無限大にもっとも近い) Float 値を返します。
log 指定された Float 値の自然対数(底はe)を返します。
log10 Float 値の10を底とする対数を返します。
nextDown 引数と1の合計の自然対数を返します。
nextUp 負の無限大方向でxに隣接する浮動小数点値を返します。
rint 正の無限大方向でxに隣接する浮動小数点値を返します。
round 引数にもっとも近い Int を返します。同数の場合は正の無限大方向に丸めます。
signum 引数の符号要素を返します。引数がゼロの場合はゼロ、引数がゼロより大きい場合は1.0、引数がゼロより小さい場合は -1.0です。
sin 指定された角度の正弦(サイン)を返します。
sinh Float 値の双曲線正弦を返します。
sqrt Float 値の正しく丸めた正の平方根を返します。
tan 指定された角度の正接(タンジェント)を返します。
tanh Float 値の双曲線正接を返します。
degrees ラジアンで計測した角度を、相当する度に変換します。
radians 度で計測した角度を、相当するラジアンに変換します。
ulp 引数のulpのサイズを返します。

制御構文演算子

begin-end 演算子

複文演算子ともいいます。 この演算子は、ブロックの中に含まれる複数の式を順次実行します。 最後の式の値が戻り値になります。

Input  => z = begin
            x = 1
            y = 2
            x + y
          end
Output => 3

if 演算子

if "条件式"
  "ブロック"
end

この演算子は、条件式が true のとき、ブロックを実行します。 ブロックの最後の式の値が戻り値になります。 条件式が false のときは false が戻り値になります。

if-else 演算子

if "条件式"
  "if-ブロック"
else
  "else-ブロック"
end

この演算子は、条件式が true のとき、if-ブロックを実行し、 false のときは else-ブロックが実行されます。 実行されたブロックの最後の式の値が戻り値になります。

if-elseif-else 句

if "条件式"
  "if-ブロック"
elseif "条件式"
  "elseif-ブロック"
else
  "else-ブロック"
end

この型は if if-else 演算子を組み合わせた糖衣構文です。 Q0 では上の文は下に置き換えられてから計算されます。

if "条件式"
  "if-ブロック"
else
  if "条件式"
    "if-ブロック"
  else
    "else-ブロック"
  end
end

if 演算子と if-else 演算子もまとめて if-elseif-else 句ということもあります。 if-elseif-else 句の使用例を下に示します。

Input  => x = e^π
          y = π^e
          if x < y
              "x is less than y"
          elseif x > y
              "x is greater than y"
          else
              "x is equal to y"
          end
Output => "x is greater than y"

while 演算子

while 演算子は、条件式を評価し、その式が true である間、 while 演算子の評価を続けます。 条件式の評価が false に初めてなると、その後、本体は決して評価されません。 返り値は最後に評価された式の値が戻り値になります。

Input  => i = 1
          sum = 0
          while 1 <= i <= 10
            sum = sum + i
            i = i + 1
          end
          sum
Output => 55

上に示した計算式は while 演算子を使って、 1 から 10 までの和を求める式です。 これらの 4 つの計算式は以下のように計算されます。

$1 = (i = 1)
   = 1
$2 = (sum = 0)
   = 0
$3 = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 1) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (1 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (0 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (0 + 1)); (i = (i + 1))) end)
   = (while true; ((sum = 1); (i = (i + 1))) end)
   = (while true; (1; (i = (i + 1))) end)
   = (while true; (1; (i = (1 + 1))) end)
   = (while true; (1; (i = 2)) end)
   = (while true; (1; 2) end)
   = (while true; 2 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 2) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (2 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (1 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (1 + 2)); (i = (i + 1))) end)
   = (while true; ((sum = 3); (i = (i + 1))) end)
   = (while true; (3; (i = (i + 1))) end)
   = (while true; (3; (i = (2 + 1))) end)
   = (while true; (3; (i = 3)) end)
   = (while true; (3; 3) end)
   = (while true; 3 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 3) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (3 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (3 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (3 + 3)); (i = (i + 1))) end)
   = (while true; ((sum = 6); (i = (i + 1))) end)
   = (while true; (6; (i = (i + 1))) end)
   = (while true; (6; (i = (3 + 1))) end)
   = (while true; (6; (i = 4)) end)
   = (while true; (6; 4) end)
   = (while true; 4 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 4) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (4 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (6 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (6 + 4)); (i = (i + 1))) end)
   = (while true; ((sum = 10); (i = (i + 1))) end)
   = (while true; (10; (i = (i + 1))) end)
   = (while true; (10; (i = (4 + 1))) end)
   = (while true; (10; (i = 5)) end)
   = (while true; (10; 5) end)
   = (while true; 5 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 5) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (5 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (10 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (10 + 5)); (i = (i + 1))) end)
   = (while true; ((sum = 15); (i = (i + 1))) end)
   = (while true; (15; (i = (i + 1))) end)
   = (while true; (15; (i = (5 + 1))) end)
   = (while true; (15; (i = 6)) end)
   = (while true; (15; 6) end)
   = (while true; 6 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 6) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (6 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (15 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (15 + 6)); (i = (i + 1))) end)
   = (while true; ((sum = 21); (i = (i + 1))) end)
   = (while true; (21; (i = (i + 1))) end)
   = (while true; (21; (i = (6 + 1))) end)
   = (while true; (21; (i = 7)) end)
   = (while true; (21; 7) end)
   = (while true; 7 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 7) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (7 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (21 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (21 + 7)); (i = (i + 1))) end)
   = (while true; ((sum = 28); (i = (i + 1))) end)
   = (while true; (28; (i = (i + 1))) end)
   = (while true; (28; (i = (7 + 1))) end)
   = (while true; (28; (i = 8)) end)
   = (while true; (28; 8) end)
   = (while true; 8 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 8) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (8 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (28 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (28 + 8)); (i = (i + 1))) end)
   = (while true; ((sum = 36); (i = (i + 1))) end)
   = (while true; (36; (i = (i + 1))) end)
   = (while true; (36; (i = (8 + 1))) end)
   = (while true; (36; (i = 9)) end)
   = (while true; (36; 9) end)
   = (while true; 9 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 9) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (9 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (36 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (36 + 9)); (i = (i + 1))) end)
   = (while true; ((sum = 45); (i = (i + 1))) end)
   = (while true; (45; (i = (i + 1))) end)
   = (while true; (45; (i = (9 + 1))) end)
   = (while true; (45; (i = 10)) end)
   = (while true; (45; 10) end)
   = (while true; 10 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 10) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (10 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (sum + i)); (i = (i + 1))) end)
   = (while true; ((sum = (45 + i)); (i = (i + 1))) end)
   = (while true; ((sum = (45 + 10)); (i = (i + 1))) end)
   = (while true; ((sum = 55); (i = (i + 1))) end)
   = (while true; (55; (i = (i + 1))) end)
   = (while true; (55; (i = (10 + 1))) end)
   = (while true; (55; (i = 11)) end)
   = (while true; (55; 11) end)
   = (while true; 11 end)
   = (while ((1 <= i) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while ((1 <= 11) <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while (11 <= 10); ((sum = (sum + i)); (i = (i + 1))) end)
   = (while false; ((sum = (sum + i)); (i = (i + 1))) end)
   = 11
$4 = sum
   = 55

About

Java Simple Calculation (課題のために作られた電卓プログラム)

Topics

Resources

Stars

Watchers

Forks

Languages