[주의!] 문서의 이전 버전(에 수정)을 보고 있습니다. 최신 버전으로 이동
분류

1. [편집]


https://theseed.io/backlink/%EB%AC%B8%EC%84%9C:%20

b == 65534
65534?
전엔 29970아니였냐
---
b == 32768
---
b == 1
1sid1<바뀜 asdf<안바뀜
---
[ ]


}}}

[include({{{#red asdf)]
}}}

red


[include({{{)]

.

.



그렇다. 그긴거는 필요없었다.흑흑
하지만 소수점 아랫쪽은 필요했다는 무시무시한 사실


5 5
5자


5 5
5자
<#fff">왜 문제가 없지
folding, wiki(스타일), html은 뒤에 띄어쓰기 없어도 작동.
다만 dark-style은 꼭 "-"만 사용 가능.
if, syntax는 띄어쓰기 없을 시 에러.

2. 계산기 테스트[편집]


  1. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.
    Case 1-1 : rb가 0 이상인 경우
    rb가 소수점 아래 자릿수를 초과하여 소수점 위의 수를 계산하게 생겼다면 ap=bp인 상황에서 rp>ap가 됩니다. rb는 첫 숫자가 1인 정수가 되므로 첫 숫자인 1을 삭제한 문자열로 정의합니다.

    rb가 소수점 아래 자릿수를 초과하지 않을 경우 rb를 다시 정의할 필요 없이 그대로 둡니다.



    Case 1-2 : rb가 음수인 경우 ru에서 1을 빌려옵니다. 1보다 작은 양수값에서 1보다 작은 양수값을 빼면 -1보다 작을 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1.1 - (-1.2) = 2.3

  2. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.


    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    [오류] 변수 a와 b에 범위를 초과하는 값이 입력되었습니다. (오버플로)

  3. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.


    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    123456789012345678 - (-901234567890123456)
    = 1024691356902469134

  4. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.
    .12345 식으로 또는 -.12345 식으로 기입할 경우 upper 값을 0으로 부여합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.


    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    . - (-.) → 0 - 0 = 0

  5. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.


    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    (-) + (-) → 0 + 0 = 0

  6. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.


    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    12345 - 67890 = -55545

  7. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.


    나눗셈은 소수점 위 18번째 자리부터 내려가면서 처음으로 0이 아닌 숫자가 있으면 그 숫자가 처음 숫자가 되도록 숫자를 왼쪽으로 밀어두려고 합니다. 그 다음 오른쪽을 0으로 채웁니다.

    a에서 au가 0인 경우 18자리 au를 18자리 ab로 바꾸고 ab를 18자의 0(pd)으로 채웁니다.
    소수점 아래 자리를 매겼던 ab가 소수점 위인 au자리로 옮겨지게 되므로 정수로 바꾸었다 다시 문자열로 바꿈으로써 왼쪽에 불필요하게 붙어있는 0을 삭제합니다.


    au를 왼쪽으로 밀 경우 남게 되는 자릿수를 변수 tu로 둡니다. (후술할 아래 곱셈연산과 겹치지 않습니다.)


    b도 a와 같은 방법으로 초기화합니다.



    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.
    au, ab, bu, bb를 18자로 만들었으므로 36자리 정수의 나눗셈으로 봅니다.
    a/b=(au+ab)/(bu+bb)=(+(au.substr(0,18)+ab.substr(0,18)))/(+(bu.substr(0,18)+bb.substr(0,18)))와 같습니다.

    제일 높은 자리부터 내려오면서 처음으로 0이 아닌 수를 왼쪽으로 당기는 과정을 거쳤으므로 (1부터 시작하는 18자리+18자리 숫자)/(1부터 시작하는 18자리+18자리 수) 연산이 됩니다.

    ps를 false로 초기화합니다. 변수에 값을 주는 여부로 ps를 사용합니다.

    다시 정렬된 bu, bb의 값은 바뀌지 않습니다. bu, bb로 나눈 몫만큼 au, ab에서 감소시킨 다음 au와 ab를 다시 정렬시키며, au와 ab가 모두 0이 되면 더 이상 계산하지 않도록 br를 true로 반환합니다.
    그 다음 계산을 편하게 할 수 있도록 텍스트값으로 된 au, ab, bu, bb를 정수값으로 변환합니다.


    먼저 au를 bu로 나눈 몫을 tw로 정의합니다. 정수를 정수로 나누면 몫만 계산되며, 100,000,000,000,000,000 이상 999,999,999 999,999,999 이하의 한 정수를 100,000,000,000,000,000 이상의 다른 한 정수로 나눈 몫이므로 tw의 값은 최소 0 최대 9가 됩니다.

    bu, bb를 각각 tw만큼 곱한 값을 tx, ty로 정의합니다.

    이 때 ty가 19자리가 되면 넘친 첫번째 자리의 값을 tx의 일의 자리로 더하고 아래 18자리의 값을 ty로 다시 정의합니다. tx는 19자리 숫자가 되어도 문제가 없습니다. 만일 ty가 19자리가 되지 않는다면 tx와 ty를 그대로 둡니다. 그 다음 ty를 정수로 바꿉니다.

    이렇게 하면 tx=bu*tw<=au가 됩니다. (bu가 au보다 크면 tw는 tw의 정의에서 값이 0이 되므로 부등호가 성립됩니다.)

    (2.1/1.6 처럼) ty가 넘쳐 tx 값이 더해지는 경우가 있으므로 몫이 유효한 값인지 검산합니다. 만일 tx ty 가 기존 au ab을 넘게 되면 tw에서 1을 빼고, tx, ty를 다시 정의합니다. 그러나 tw가 이미 0이 되었을 경우 tw를 0으로 둡니다.

    이렇게 만들어진 tx, ty가 있으면 이를 반영합니다.
    au에서 tx를, ab에서 ty를 뺍니다. 만약 ty>ab일 경우 au에서 1을 가져와 (au에서 1을 빼고) ab에 1,000,000,000,000,000,000을 더한 다음 계산합니다.


    몫인 tw를 문자열로 바꾸고 tm의 오른쪽에 더합니다.

    au, ab에서 몫을 빼고 나니 au, ab가 모두 0으로 된다면 더 이상 계산을 하지 않아야 하므로 br를 true로 반환합니다.

    어느 하나가 0이 되지 않는다면 br는 여전히 false이므로 !br일 때 자릿수를 옮깁니다.
    au, ab를 문자열로 다시 바꿉니다.

    au가 여전히 18자리 숫자일 경우 au의 첫번째 자리를 분리해 내어 tn으로 정의하고 나머지 17자리를 au로 둡니다. 그렇지 않을 경우 (au가 17자리 미만의 숫자가 되었다면) tn은 빈 문자열으로 두고 au의 왼쪽을 0(pd)으로 채운 다음 (적어도 19자리가 되는 문자열을) 뒤에서 17번째 자리부터 가지고 와 au로 만듭니다.

    ab가 18자리 미만의 숫자가 되었다면 왼쪽을 0으로 채워 18자리 숫자로 만듭니다.

    au의 뒤로 ab의 처음 자리를 끌어옵니다.

    ab의 나머지 17자리를 앞으로 당긴 다음 "0"을 더합니다.

    여기까지가 자릿수를 한 칸씩 옮기는 과정입니다.
    몫으로 기록할 숫자의 첫번째 자리를 구했다면, 그 다음 자리의 숫자를 찾기 위해 (변수 tn으로 만들 수 있는 여분의 1자리 +) 18자리 + 18자리 숫자를 18자리+18자리 숫자로 나누는 계산을 합니다. tn이 9가 될 경우 9로 시작하는 19자리 숫자를 long integer로 모두 표현할 수 없으므로 10**18 자리부터 먼저 계산합니다. 10**18의 1번째 숫자의 몫을 구한 다음 나머지를 18자리 숫자에 더하는 과정(part 1)을 거친 다음 그 18자리에서 몫을 구하는 과정(part 2)을 거칩니다.

    au와 ab를 정수로 다시 바꾸고 tz를 0으로 초기화합니다. 그리고 tn이 빈 문자열이 아니라면 (앞에 au에서 한 자리 수를 떼온 것이므로) tn에 0을 더하여 19자리로 만들고 몫을 구합니다.
    tn을 19자리 정수로 바꿉니다.

    tz를 몫으로 정의합니다. 앞의 tw를 처리하는 방법과 같습니다. tn을 정수로 만들었으므로 소수점 아래를 비교한다면 정수의 소수점 아래에 해당하는 0과 비교합니다.

    마찬가지로 ty가 19자리 숫자이면 1자리를 떼어 tx에 더합니다.

    앞의 tw를 처리할 때 au와 tx를 비교한 것처럼 tz를 처리할 때 tn와 tx를 비교합니다.

    tn에서 나누어떨어지는 값을 뺀 나머지를 반영하여 au, ab에 더합니다. 소수점 아래 부분인 ab보다 ty가 크다면 tn에서 1을 빼어 계산합니다.


    tn을 빈 문자열로 초기화합니다.

    br(0으로 나누어떨어짐) 이 걸려있으면 실행하지 않습니다. 그러므로 전체적으로 조건을 !br로 둔 다음 계산을 진행합니다.
    tw, tx, ty를 정의하고 처리하는 과정은 앞자리에서 몫을 찾는 과정과 동일합니다. 앞의 part 1에서 이미 au, ab를 정수로 만들었으므로 여기에 au, ab를 정수로 만드는 처리를 할 필요가 없습니다.

    ty를 정수로 바꾸는 과정을 아래 if 조건문으로 병합합니다.


    앞에서 계산된 tz의 값을 tw에 더한 다음 tw를 문자열로 바꿉니다. 그리고 tm에 문자열로 바꾼 tw을 더합니다.

    au와 ab가 모두 0이 될 때 br를 true로 정의합니다.

    어느 자릿수부터 br가 true로 되면 이후 자릿수 옮겨 몫을 구하는 과정이나 나머지를 정리하는 과정을 더 이상 할 필요가 없습니다.
    au, ab를 문자열로 다시 바꾸고 처리하는 과정은 동일합니다.

    ps를 au 자릿수가 18이 되었을 때 true가 되는 논리값으로 정의합니다.



    이후부터 과정은 동일합니다. 많아야 소수점 위 36자리, 소수점 아래 36자리 모두를 쓰면 72개이므로 총 72회(for i=0 to i=71)를 진행합니다.



















































































































































    tn을 빈 문자열로 초기화하고 변수 ts를 가져옵니다. 마지막 72회까지 몫을 구하는 계산을 했음에도 불구하고 나머지가 나누어떨어져 0이 되지 않는다면 tn을 "..."로, ts를 true로 바꿉니다.


    앞에 매겼던 ac와 bc로 판별식을 만듭니다. i=ac-bc로 둡니다. a의 가장 큰 자리와 b의 가장 큰 자리가 얼마나 차이나는가에 따라 몫에 매기는 소수점 위치가 달라집니다. i>=-35 (ac==-18이고 bc==17일 경우), i<=35 (ac==17이고 bc=-18일 경우)입니다.

    a에서 b를 나누면 몫을 10^i 의 자리부터 매기게 됩니다. 소수점 아랫부분까지 몫 기록이 이어지면 상관이 없겠으나, 몫이 소수가 아닌 정수로 기록될 때 실제 자릿수에 해당하는 길이보다 (금방 나누어떨어져) 몫이 짧게 기록되고 그치는 경우 남는 자리에 자동적으로 0을 채워주지 않게 됩니다. 이러면 수동으로 0을 채워주어야 하며, (i==0일 경우 10^0의 자리부터 몫을 기록하므로 10^1과 같거나 큰 자리부터 기록할 경우 곧) i>0일 때에만 의미가 있습니다.
    이를테면 4000/2를 계산하는 경우 몫이 "2"까지만 기록되며 뒤에 000은 수동으로 채워주어야 합니다.
    몫은 tm으로 기록되므로 tm의 길이를 따집니다. i가 양수이고 몫이 정수로 나누어떨어질 경우, tm의 길이가 적어도 i+1이 되게 맞춥니다.


    i가 18 이상 (18 이상 35 이하)이면 rs를 매길 수 있습니다. 몫을 적어놓은 문자열 tm의 0번 index에 들어가는 문자부터 i에서 18을 뺀 값의 index에 들어가는 문자까지를 rs로 두며, rs의 문자열 길이는 i-18+1 곧 i-17입니다.


    ps를 먼저 false로 초기화한 다음, i>=18 이 되(어 rs를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 ru로 두고, tm에서 ru를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 (i가 충분히 큰 값이 아니고) i가 0 이상 (0 이상 17 이하)인 수라면 ru를 매길 수 있으며 문자열의 길이는 i+1이 됩니다.


    i>=0이 되(어 ru를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 rb로 두고, tm에서 rb를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 i가 -18 이상 (-18 이상 -1 이하)이면 rb를 매길 수 있습니다.
    이 때 몫으로 문자열의 길이는 i+18+1 곧 i+19가 되며 그 앞부분은 0으로 채워집니다.
    몫으로 i+19개의 자리가 채워진다면, 몫 앞을 0으로 채우는 수량은 18에서 i+19를 뺀 -i-1이 됩니다.
    이것을 substr을 이용하여 (18자리 문자열인) pd의 substr로 채워보자면
    18에서 (-i-1)을 뺀 i+19 번부터 끝까지 해당하는 문자열로 채우면 됩니다.


    i>=-18이 되(어 rb를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 rb와 같은 방법으로 ri를 매기고, tm을 다시 정의합니다.

    ps가 false이며 i가 -19 이하 (-36이상 -19 이하이나, i의 최소값은 -35)이면 ri를 매길 수 있습니다. rb와 같습니다.


    ri까지 몫을 기록했음에도 불구하고 여전히 몫이 남는다면 ... 처리를 하고 ts를 true로 바꿉니다. 단, 나눗셈이 나누어떨어지는 식의 경우 경고 코드 2번을 반환합니다.


    여기까지가 나눗셈의 계산과정입니다.

    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    123459 / 2 = 61729.5

  8. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.


    나눗셈은 소수점 위 18번째 자리부터 내려가면서 처음으로 0이 아닌 숫자가 있으면 그 숫자가 처음 숫자가 되도록 숫자를 왼쪽으로 밀어두려고 합니다. 그 다음 오른쪽을 0으로 채웁니다.

    a에서 au가 0인 경우 18자리 au를 18자리 ab로 바꾸고 ab를 18자의 0(pd)으로 채웁니다.
    소수점 아래 자리를 매겼던 ab가 소수점 위인 au자리로 옮겨지게 되므로 정수로 바꾸었다 다시 문자열로 바꿈으로써 왼쪽에 불필요하게 붙어있는 0을 삭제합니다.


    au를 왼쪽으로 밀 경우 남게 되는 자릿수를 변수 tu로 둡니다. (후술할 아래 곱셈연산과 겹치지 않습니다.)


    b도 a와 같은 방법으로 초기화합니다.



    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.
    au, ab, bu, bb를 18자로 만들었으므로 36자리 정수의 나눗셈으로 봅니다.
    a/b=(au+ab)/(bu+bb)=(+(au.substr(0,18)+ab.substr(0,18)))/(+(bu.substr(0,18)+bb.substr(0,18)))와 같습니다.

    제일 높은 자리부터 내려오면서 처음으로 0이 아닌 수를 왼쪽으로 당기는 과정을 거쳤으므로 (1부터 시작하는 18자리+18자리 숫자)/(1부터 시작하는 18자리+18자리 수) 연산이 됩니다.

    ps를 false로 초기화합니다. 변수에 값을 주는 여부로 ps를 사용합니다.

    다시 정렬된 bu, bb의 값은 바뀌지 않습니다. bu, bb로 나눈 몫만큼 au, ab에서 감소시킨 다음 au와 ab를 다시 정렬시키며, au와 ab가 모두 0이 되면 더 이상 계산하지 않도록 br를 true로 반환합니다.
    그 다음 계산을 편하게 할 수 있도록 텍스트값으로 된 au, ab, bu, bb를 정수값으로 변환합니다.


    먼저 au를 bu로 나눈 몫을 tw로 정의합니다. 정수를 정수로 나누면 몫만 계산되며, 100,000,000,000,000,000 이상 999,999,999 999,999,999 이하의 한 정수를 100,000,000,000,000,000 이상의 다른 한 정수로 나눈 몫이므로 tw의 값은 최소 0 최대 9가 됩니다.

    bu, bb를 각각 tw만큼 곱한 값을 tx, ty로 정의합니다.

    이 때 ty가 19자리가 되면 넘친 첫번째 자리의 값을 tx의 일의 자리로 더하고 아래 18자리의 값을 ty로 다시 정의합니다. tx는 19자리 숫자가 되어도 문제가 없습니다. 만일 ty가 19자리가 되지 않는다면 tx와 ty를 그대로 둡니다. 그 다음 ty를 정수로 바꿉니다.

    이렇게 하면 tx=bu*tw<=au가 됩니다. (bu가 au보다 크면 tw는 tw의 정의에서 값이 0이 되므로 부등호가 성립됩니다.)

    (2.1/1.6 처럼) ty가 넘쳐 tx 값이 더해지는 경우가 있으므로 몫이 유효한 값인지 검산합니다. 만일 tx ty 가 기존 au ab을 넘게 되면 tw에서 1을 빼고, tx, ty를 다시 정의합니다. 그러나 tw가 이미 0이 되었을 경우 tw를 0으로 둡니다.

    이렇게 만들어진 tx, ty가 있으면 이를 반영합니다.
    au에서 tx를, ab에서 ty를 뺍니다. 만약 ty>ab일 경우 au에서 1을 가져와 (au에서 1을 빼고) ab에 1,000,000,000,000,000,000을 더한 다음 계산합니다.


    몫인 tw를 문자열로 바꾸고 tm의 오른쪽에 더합니다.

    au, ab에서 몫을 빼고 나니 au, ab가 모두 0으로 된다면 더 이상 계산을 하지 않아야 하므로 br를 true로 반환합니다.

    어느 하나가 0이 되지 않는다면 br는 여전히 false이므로 !br일 때 자릿수를 옮깁니다.
    au, ab를 문자열로 다시 바꿉니다.

    au가 여전히 18자리 숫자일 경우 au의 첫번째 자리를 분리해 내어 tn으로 정의하고 나머지 17자리를 au로 둡니다. 그렇지 않을 경우 (au가 17자리 미만의 숫자가 되었다면) tn은 빈 문자열으로 두고 au의 왼쪽을 0(pd)으로 채운 다음 (적어도 19자리가 되는 문자열을) 뒤에서 17번째 자리부터 가지고 와 au로 만듭니다.

    ab가 18자리 미만의 숫자가 되었다면 왼쪽을 0으로 채워 18자리 숫자로 만듭니다.

    au의 뒤로 ab의 처음 자리를 끌어옵니다.

    ab의 나머지 17자리를 앞으로 당긴 다음 "0"을 더합니다.

    여기까지가 자릿수를 한 칸씩 옮기는 과정입니다.
    몫으로 기록할 숫자의 첫번째 자리를 구했다면, 그 다음 자리의 숫자를 찾기 위해 (변수 tn으로 만들 수 있는 여분의 1자리 +) 18자리 + 18자리 숫자를 18자리+18자리 숫자로 나누는 계산을 합니다. tn이 9가 될 경우 9로 시작하는 19자리 숫자를 long integer로 모두 표현할 수 없으므로 10**18 자리부터 먼저 계산합니다. 10**18의 1번째 숫자의 몫을 구한 다음 나머지를 18자리 숫자에 더하는 과정(part 1)을 거친 다음 그 18자리에서 몫을 구하는 과정(part 2)을 거칩니다.

    au와 ab를 정수로 다시 바꾸고 tz를 0으로 초기화합니다. 그리고 tn이 빈 문자열이 아니라면 (앞에 au에서 한 자리 수를 떼온 것이므로) tn에 0을 더하여 19자리로 만들고 몫을 구합니다.
    tn을 19자리 정수로 바꿉니다.

    tz를 몫으로 정의합니다. 앞의 tw를 처리하는 방법과 같습니다. tn을 정수로 만들었으므로 소수점 아래를 비교한다면 정수의 소수점 아래에 해당하는 0과 비교합니다.

    마찬가지로 ty가 19자리 숫자이면 1자리를 떼어 tx에 더합니다.

    앞의 tw를 처리할 때 au와 tx를 비교한 것처럼 tz를 처리할 때 tn와 tx를 비교합니다.

    tn에서 나누어떨어지는 값을 뺀 나머지를 반영하여 au, ab에 더합니다. 소수점 아래 부분인 ab보다 ty가 크다면 tn에서 1을 빼어 계산합니다.


    tn을 빈 문자열로 초기화합니다.

    br(0으로 나누어떨어짐) 이 걸려있으면 실행하지 않습니다. 그러므로 전체적으로 조건을 !br로 둔 다음 계산을 진행합니다.
    tw, tx, ty를 정의하고 처리하는 과정은 앞자리에서 몫을 찾는 과정과 동일합니다. 앞의 part 1에서 이미 au, ab를 정수로 만들었으므로 여기에 au, ab를 정수로 만드는 처리를 할 필요가 없습니다.

    ty를 정수로 바꾸는 과정을 아래 if 조건문으로 병합합니다.


    앞에서 계산된 tz의 값을 tw에 더한 다음 tw를 문자열로 바꿉니다. 그리고 tm에 문자열로 바꾼 tw을 더합니다.

    au와 ab가 모두 0이 될 때 br를 true로 정의합니다.

    어느 자릿수부터 br가 true로 되면 이후 자릿수 옮겨 몫을 구하는 과정이나 나머지를 정리하는 과정을 더 이상 할 필요가 없습니다.
    au, ab를 문자열로 다시 바꾸고 처리하는 과정은 동일합니다.

    ps를 au 자릿수가 18이 되었을 때 true가 되는 논리값으로 정의합니다.



    이후부터 과정은 동일합니다. 많아야 소수점 위 36자리, 소수점 아래 36자리 모두를 쓰면 72개이므로 총 72회(for i=0 to i=71)를 진행합니다.























































































































































































































































































    tn을 빈 문자열로 초기화하고 변수 ts를 가져옵니다. 마지막 72회까지 몫을 구하는 계산을 했음에도 불구하고 나머지가 나누어떨어져 0이 되지 않는다면 tn을 "..."로, ts를 true로 바꿉니다.


    앞에 매겼던 ac와 bc로 판별식을 만듭니다. i=ac-bc로 둡니다. a의 가장 큰 자리와 b의 가장 큰 자리가 얼마나 차이나는가에 따라 몫에 매기는 소수점 위치가 달라집니다. i>=-35 (ac==-18이고 bc==17일 경우), i<=35 (ac==17이고 bc=-18일 경우)입니다.

    a에서 b를 나누면 몫을 10^i 의 자리부터 매기게 됩니다. 소수점 아랫부분까지 몫 기록이 이어지면 상관이 없겠으나, 몫이 소수가 아닌 정수로 기록될 때 실제 자릿수에 해당하는 길이보다 (금방 나누어떨어져) 몫이 짧게 기록되고 그치는 경우 남는 자리에 자동적으로 0을 채워주지 않게 됩니다. 이러면 수동으로 0을 채워주어야 하며, (i==0일 경우 10^0의 자리부터 몫을 기록하므로 10^1과 같거나 큰 자리부터 기록할 경우 곧) i>0일 때에만 의미가 있습니다.
    이를테면 4000/2를 계산하는 경우 몫이 "2"까지만 기록되며 뒤에 000은 수동으로 채워주어야 합니다.
    몫은 tm으로 기록되므로 tm의 길이를 따집니다. i가 양수이고 몫이 정수로 나누어떨어질 경우, tm의 길이가 적어도 i+1이 되게 맞춥니다.


    i가 18 이상 (18 이상 35 이하)이면 rs를 매길 수 있습니다. 몫을 적어놓은 문자열 tm의 0번 index에 들어가는 문자부터 i에서 18을 뺀 값의 index에 들어가는 문자까지를 rs로 두며, rs의 문자열 길이는 i-18+1 곧 i-17입니다.


    ps를 먼저 false로 초기화한 다음, i>=18 이 되(어 rs를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 ru로 두고, tm에서 ru를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 (i가 충분히 큰 값이 아니고) i가 0 이상 (0 이상 17 이하)인 수라면 ru를 매길 수 있으며 문자열의 길이는 i+1이 됩니다.


    i>=0이 되(어 ru를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 rb로 두고, tm에서 rb를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 i가 -18 이상 (-18 이상 -1 이하)이면 rb를 매길 수 있습니다.
    이 때 몫으로 문자열의 길이는 i+18+1 곧 i+19가 되며 그 앞부분은 0으로 채워집니다.
    몫으로 i+19개의 자리가 채워진다면, 몫 앞을 0으로 채우는 수량은 18에서 i+19를 뺀 -i-1이 됩니다.
    이것을 substr을 이용하여 (18자리 문자열인) pd의 substr로 채워보자면
    18에서 (-i-1)을 뺀 i+19 번부터 끝까지 해당하는 문자열로 채우면 됩니다.


    i>=-18이 되(어 rb를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 rb와 같은 방법으로 ri를 매기고, tm을 다시 정의합니다.

    ps가 false이며 i가 -19 이하 (-36이상 -19 이하이나, i의 최소값은 -35)이면 ri를 매길 수 있습니다. rb와 같습니다.


    ri까지 몫을 기록했음에도 불구하고 여전히 몫이 남는다면 ... 처리를 하고 ts를 true로 바꿉니다. 단, 나눗셈이 나누어떨어지는 식의 경우 경고 코드 2번을 반환합니다.


    여기까지가 나눗셈의 계산과정입니다.

    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    10 / 3 = 3.333333333333333333333333333333333333...

  9. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.


    나눗셈은 소수점 위 18번째 자리부터 내려가면서 처음으로 0이 아닌 숫자가 있으면 그 숫자가 처음 숫자가 되도록 숫자를 왼쪽으로 밀어두려고 합니다. 그 다음 오른쪽을 0으로 채웁니다.

    a에서 au가 0인 경우 18자리 au를 18자리 ab로 바꾸고 ab를 18자의 0(pd)으로 채웁니다.
    소수점 아래 자리를 매겼던 ab가 소수점 위인 au자리로 옮겨지게 되므로 정수로 바꾸었다 다시 문자열로 바꿈으로써 왼쪽에 불필요하게 붙어있는 0을 삭제합니다.


    au를 왼쪽으로 밀 경우 남게 되는 자릿수를 변수 tu로 둡니다. (후술할 아래 곱셈연산과 겹치지 않습니다.)


    b도 a와 같은 방법으로 초기화합니다.



    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.
    au, ab, bu, bb를 18자로 만들었으므로 36자리 정수의 나눗셈으로 봅니다.
    a/b=(au+ab)/(bu+bb)=(+(au.substr(0,18)+ab.substr(0,18)))/(+(bu.substr(0,18)+bb.substr(0,18)))와 같습니다.

    제일 높은 자리부터 내려오면서 처음으로 0이 아닌 수를 왼쪽으로 당기는 과정을 거쳤으므로 (1부터 시작하는 18자리+18자리 숫자)/(1부터 시작하는 18자리+18자리 수) 연산이 됩니다.

    ps를 false로 초기화합니다. 변수에 값을 주는 여부로 ps를 사용합니다.

    다시 정렬된 bu, bb의 값은 바뀌지 않습니다. bu, bb로 나눈 몫만큼 au, ab에서 감소시킨 다음 au와 ab를 다시 정렬시키며, au와 ab가 모두 0이 되면 더 이상 계산하지 않도록 br를 true로 반환합니다.
    그 다음 계산을 편하게 할 수 있도록 텍스트값으로 된 au, ab, bu, bb를 정수값으로 변환합니다.


    먼저 au를 bu로 나눈 몫을 tw로 정의합니다. 정수를 정수로 나누면 몫만 계산되며, 100,000,000,000,000,000 이상 999,999,999 999,999,999 이하의 한 정수를 100,000,000,000,000,000 이상의 다른 한 정수로 나눈 몫이므로 tw의 값은 최소 0 최대 9가 됩니다.

    bu, bb를 각각 tw만큼 곱한 값을 tx, ty로 정의합니다.

    이 때 ty가 19자리가 되면 넘친 첫번째 자리의 값을 tx의 일의 자리로 더하고 아래 18자리의 값을 ty로 다시 정의합니다. tx는 19자리 숫자가 되어도 문제가 없습니다. 만일 ty가 19자리가 되지 않는다면 tx와 ty를 그대로 둡니다. 그 다음 ty를 정수로 바꿉니다.

    이렇게 하면 tx=bu*tw<=au가 됩니다. (bu가 au보다 크면 tw는 tw의 정의에서 값이 0이 되므로 부등호가 성립됩니다.)

    (2.1/1.6 처럼) ty가 넘쳐 tx 값이 더해지는 경우가 있으므로 몫이 유효한 값인지 검산합니다. 만일 tx ty 가 기존 au ab을 넘게 되면 tw에서 1을 빼고, tx, ty를 다시 정의합니다. 그러나 tw가 이미 0이 되었을 경우 tw를 0으로 둡니다.

    이렇게 만들어진 tx, ty가 있으면 이를 반영합니다.
    au에서 tx를, ab에서 ty를 뺍니다. 만약 ty>ab일 경우 au에서 1을 가져와 (au에서 1을 빼고) ab에 1,000,000,000,000,000,000을 더한 다음 계산합니다.


    몫인 tw를 문자열로 바꾸고 tm의 오른쪽에 더합니다.

    au, ab에서 몫을 빼고 나니 au, ab가 모두 0으로 된다면 더 이상 계산을 하지 않아야 하므로 br를 true로 반환합니다.

    어느 하나가 0이 되지 않는다면 br는 여전히 false이므로 !br일 때 자릿수를 옮깁니다.
    au, ab를 문자열로 다시 바꿉니다.

    au가 여전히 18자리 숫자일 경우 au의 첫번째 자리를 분리해 내어 tn으로 정의하고 나머지 17자리를 au로 둡니다. 그렇지 않을 경우 (au가 17자리 미만의 숫자가 되었다면) tn은 빈 문자열으로 두고 au의 왼쪽을 0(pd)으로 채운 다음 (적어도 19자리가 되는 문자열을) 뒤에서 17번째 자리부터 가지고 와 au로 만듭니다.

    ab가 18자리 미만의 숫자가 되었다면 왼쪽을 0으로 채워 18자리 숫자로 만듭니다.

    au의 뒤로 ab의 처음 자리를 끌어옵니다.

    ab의 나머지 17자리를 앞으로 당긴 다음 "0"을 더합니다.

    여기까지가 자릿수를 한 칸씩 옮기는 과정입니다.
    몫으로 기록할 숫자의 첫번째 자리를 구했다면, 그 다음 자리의 숫자를 찾기 위해 (변수 tn으로 만들 수 있는 여분의 1자리 +) 18자리 + 18자리 숫자를 18자리+18자리 숫자로 나누는 계산을 합니다. tn이 9가 될 경우 9로 시작하는 19자리 숫자를 long integer로 모두 표현할 수 없으므로 10**18 자리부터 먼저 계산합니다. 10**18의 1번째 숫자의 몫을 구한 다음 나머지를 18자리 숫자에 더하는 과정(part 1)을 거친 다음 그 18자리에서 몫을 구하는 과정(part 2)을 거칩니다.

    au와 ab를 정수로 다시 바꾸고 tz를 0으로 초기화합니다. 그리고 tn이 빈 문자열이 아니라면 (앞에 au에서 한 자리 수를 떼온 것이므로) tn에 0을 더하여 19자리로 만들고 몫을 구합니다.
    tn을 19자리 정수로 바꿉니다.

    tz를 몫으로 정의합니다. 앞의 tw를 처리하는 방법과 같습니다. tn을 정수로 만들었으므로 소수점 아래를 비교한다면 정수의 소수점 아래에 해당하는 0과 비교합니다.

    마찬가지로 ty가 19자리 숫자이면 1자리를 떼어 tx에 더합니다.

    앞의 tw를 처리할 때 au와 tx를 비교한 것처럼 tz를 처리할 때 tn와 tx를 비교합니다.

    tn에서 나누어떨어지는 값을 뺀 나머지를 반영하여 au, ab에 더합니다. 소수점 아래 부분인 ab보다 ty가 크다면 tn에서 1을 빼어 계산합니다.


    tn을 빈 문자열로 초기화합니다.

    br(0으로 나누어떨어짐) 이 걸려있으면 실행하지 않습니다. 그러므로 전체적으로 조건을 !br로 둔 다음 계산을 진행합니다.
    tw, tx, ty를 정의하고 처리하는 과정은 앞자리에서 몫을 찾는 과정과 동일합니다. 앞의 part 1에서 이미 au, ab를 정수로 만들었으므로 여기에 au, ab를 정수로 만드는 처리를 할 필요가 없습니다.

    ty를 정수로 바꾸는 과정을 아래 if 조건문으로 병합합니다.


    앞에서 계산된 tz의 값을 tw에 더한 다음 tw를 문자열로 바꿉니다. 그리고 tm에 문자열로 바꾼 tw을 더합니다.

    au와 ab가 모두 0이 될 때 br를 true로 정의합니다.

    어느 자릿수부터 br가 true로 되면 이후 자릿수 옮겨 몫을 구하는 과정이나 나머지를 정리하는 과정을 더 이상 할 필요가 없습니다.

    이후부터 과정은 동일합니다. 많아야 소수점 위 36자리, 소수점 아래 36자리 모두를 쓰면 72개이므로 총 72회(for i=0 to i=71)를 진행합니다.











































































































































    tn을 빈 문자열로 초기화하고 변수 ts를 가져옵니다. 마지막 72회까지 몫을 구하는 계산을 했음에도 불구하고 나머지가 나누어떨어져 0이 되지 않는다면 tn을 "..."로, ts를 true로 바꿉니다.


    앞에 매겼던 ac와 bc로 판별식을 만듭니다. i=ac-bc로 둡니다. a의 가장 큰 자리와 b의 가장 큰 자리가 얼마나 차이나는가에 따라 몫에 매기는 소수점 위치가 달라집니다. i>=-35 (ac==-18이고 bc==17일 경우), i<=35 (ac==17이고 bc=-18일 경우)입니다.

    a에서 b를 나누면 몫을 10^i 의 자리부터 매기게 됩니다. 소수점 아랫부분까지 몫 기록이 이어지면 상관이 없겠으나, 몫이 소수가 아닌 정수로 기록될 때 실제 자릿수에 해당하는 길이보다 (금방 나누어떨어져) 몫이 짧게 기록되고 그치는 경우 남는 자리에 자동적으로 0을 채워주지 않게 됩니다. 이러면 수동으로 0을 채워주어야 하며, (i==0일 경우 10^0의 자리부터 몫을 기록하므로 10^1과 같거나 큰 자리부터 기록할 경우 곧) i>0일 때에만 의미가 있습니다.
    이를테면 4000/2를 계산하는 경우 몫이 "2"까지만 기록되며 뒤에 000은 수동으로 채워주어야 합니다.


    i가 18 이상 (18 이상 35 이하)이면 rs를 매길 수 있습니다. 몫을 적어놓은 문자열 tm의 0번 index에 들어가는 문자부터 i에서 18을 뺀 값의 index에 들어가는 문자까지를 rs로 두며, rs의 문자열 길이는 i-18+1 곧 i-17입니다.


    ps를 먼저 false로 초기화한 다음, i>=18 이 되(어 rs를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 ru로 두고, tm에서 ru를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 (i가 충분히 큰 값이 아니고) i가 0 이상 (0 이상 17 이하)인 수라면 ru를 매길 수 있으며 문자열의 길이는 i+1이 됩니다.


    i>=0이 되(어 ru를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 rb로 두고, tm에서 rb를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 i가 -18 이상 (-18 이상 -1 이하)이면 rb를 매길 수 있습니다.
    이 때 몫으로 문자열의 길이는 i+18+1 곧 i+19가 되며 그 앞부분은 0으로 채워집니다.
    몫으로 i+19개의 자리가 채워진다면, 몫 앞을 0으로 채우는 수량은 18에서 i+19를 뺀 -i-1이 됩니다.
    이것을 substr을 이용하여 (18자리 문자열인) pd의 substr로 채워보자면
    18에서 (-i-1)을 뺀 i+19 번부터 끝까지 해당하는 문자열로 채우면 됩니다.

    만일 i<0이고 i가 -18보다 작아 rb에 몫을 기록하지 않고 rb보다 더 아래 자리에 기록하게 된다면 rb의 18자리를 모두 0으로 채웁니다.


    i>=-18이 되(어 rb를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 rb와 같은 방법으로 ri를 매기고, tm을 다시 정의합니다.

    ps가 false이며 i가 -19 이하 (-36이상 -19 이하이나, i의 최소값은 -35)이면 ri를 매길 수 있습니다. rb와 같습니다.


    ri까지 몫을 기록했음에도 불구하고 여전히 몫이 남는다면 ... 처리를 하고 ts를 true로 바꿉니다. 단, 나눗셈이 나누어떨어지는 식의 경우 경고 코드 2번을 반환합니다.


    여기까지가 나눗셈의 계산과정입니다.

    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    (-5) / 200 = -0.025

  10. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.


    나눗셈은 소수점 위 18번째 자리부터 내려가면서 처음으로 0이 아닌 숫자가 있으면 그 숫자가 처음 숫자가 되도록 숫자를 왼쪽으로 밀어두려고 합니다. 그 다음 오른쪽을 0으로 채웁니다.

    a에서 au가 0인 경우 18자리 au를 18자리 ab로 바꾸고 ab를 18자의 0(pd)으로 채웁니다.
    소수점 아래 자리를 매겼던 ab가 소수점 위인 au자리로 옮겨지게 되므로 정수로 바꾸었다 다시 문자열로 바꿈으로써 왼쪽에 불필요하게 붙어있는 0을 삭제합니다.


    au를 왼쪽으로 밀 경우 남게 되는 자릿수를 변수 tu로 둡니다. (후술할 아래 곱셈연산과 겹치지 않습니다.)


    b도 a와 같은 방법으로 초기화합니다.



    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.
    au, ab, bu, bb를 18자로 만들었으므로 36자리 정수의 나눗셈으로 봅니다.
    a/b=(au+ab)/(bu+bb)=(+(au.substr(0,18)+ab.substr(0,18)))/(+(bu.substr(0,18)+bb.substr(0,18)))와 같습니다.

    제일 높은 자리부터 내려오면서 처음으로 0이 아닌 수를 왼쪽으로 당기는 과정을 거쳤으므로 (1부터 시작하는 18자리+18자리 숫자)/(1부터 시작하는 18자리+18자리 수) 연산이 됩니다.

    ps를 false로 초기화합니다. 변수에 값을 주는 여부로 ps를 사용합니다.

    다시 정렬된 bu, bb의 값은 바뀌지 않습니다. bu, bb로 나눈 몫만큼 au, ab에서 감소시킨 다음 au와 ab를 다시 정렬시키며, au와 ab가 모두 0이 되면 더 이상 계산하지 않도록 br를 true로 반환합니다.
    그 다음 계산을 편하게 할 수 있도록 텍스트값으로 된 au, ab, bu, bb를 정수값으로 변환합니다.


    먼저 au를 bu로 나눈 몫을 tw로 정의합니다. 정수를 정수로 나누면 몫만 계산되며, 100,000,000,000,000,000 이상 999,999,999 999,999,999 이하의 한 정수를 100,000,000,000,000,000 이상의 다른 한 정수로 나눈 몫이므로 tw의 값은 최소 0 최대 9가 됩니다.

    bu, bb를 각각 tw만큼 곱한 값을 tx, ty로 정의합니다.

    이 때 ty가 19자리가 되면 넘친 첫번째 자리의 값을 tx의 일의 자리로 더하고 아래 18자리의 값을 ty로 다시 정의합니다. tx는 19자리 숫자가 되어도 문제가 없습니다. 만일 ty가 19자리가 되지 않는다면 tx와 ty를 그대로 둡니다. 그 다음 ty를 정수로 바꿉니다.

    이렇게 하면 tx=bu*tw<=au가 됩니다. (bu가 au보다 크면 tw는 tw의 정의에서 값이 0이 되므로 부등호가 성립됩니다.)

    (2.1/1.6 처럼) ty가 넘쳐 tx 값이 더해지는 경우가 있으므로 몫이 유효한 값인지 검산합니다. 만일 tx ty 가 기존 au ab을 넘게 되면 tw에서 1을 빼고, tx, ty를 다시 정의합니다. 그러나 tw가 이미 0이 되었을 경우 tw를 0으로 둡니다.

    이렇게 만들어진 tx, ty가 있으면 이를 반영합니다.
    au에서 tx를, ab에서 ty를 뺍니다. 만약 ty>ab일 경우 au에서 1을 가져와 (au에서 1을 빼고) ab에 1,000,000,000,000,000,000을 더한 다음 계산합니다.


    몫인 tw를 문자열로 바꾸고 tm의 오른쪽에 더합니다.

    au, ab에서 몫을 빼고 나니 au, ab가 모두 0으로 된다면 더 이상 계산을 하지 않아야 하므로 br를 true로 반환합니다.

    어느 하나가 0이 되지 않는다면 br는 여전히 false이므로 !br일 때 자릿수를 옮깁니다.
    au, ab를 문자열로 다시 바꿉니다.

    au가 여전히 18자리 숫자일 경우 au의 첫번째 자리를 분리해 내어 tn으로 정의하고 나머지 17자리를 au로 둡니다. 그렇지 않을 경우 (au가 17자리 미만의 숫자가 되었다면) tn은 빈 문자열으로 두고 au의 왼쪽을 0(pd)으로 채운 다음 (적어도 19자리가 되는 문자열을) 뒤에서 17번째 자리부터 가지고 와 au로 만듭니다.

    ab가 18자리 미만의 숫자가 되었다면 왼쪽을 0으로 채워 18자리 숫자로 만듭니다.

    au의 뒤로 ab의 처음 자리를 끌어옵니다.

    ab의 나머지 17자리를 앞으로 당긴 다음 "0"을 더합니다.

    여기까지가 자릿수를 한 칸씩 옮기는 과정입니다.
    몫으로 기록할 숫자의 첫번째 자리를 구했다면, 그 다음 자리의 숫자를 찾기 위해 (변수 tn으로 만들 수 있는 여분의 1자리 +) 18자리 + 18자리 숫자를 18자리+18자리 숫자로 나누는 계산을 합니다. tn이 9가 될 경우 9로 시작하는 19자리 숫자를 long integer로 모두 표현할 수 없으므로 10**18 자리부터 먼저 계산합니다. 10**18의 1번째 숫자의 몫을 구한 다음 나머지를 18자리 숫자에 더하는 과정(part 1)을 거친 다음 그 18자리에서 몫을 구하는 과정(part 2)을 거칩니다.

    au와 ab를 정수로 다시 바꾸고 tz를 0으로 초기화합니다. 그리고 tn이 빈 문자열이 아니라면 (앞에 au에서 한 자리 수를 떼온 것이므로) tn에 0을 더하여 19자리로 만들고 몫을 구합니다.
    tn을 19자리 정수로 바꿉니다.

    tz를 몫으로 정의합니다. 앞의 tw를 처리하는 방법과 같습니다. tn을 정수로 만들었으므로 소수점 아래를 비교한다면 정수의 소수점 아래에 해당하는 0과 비교합니다.

    마찬가지로 ty가 19자리 숫자이면 1자리를 떼어 tx에 더합니다.

    앞의 tw를 처리할 때 au와 tx를 비교한 것처럼 tz를 처리할 때 tn와 tx를 비교합니다.

    tn에서 나누어떨어지는 값을 뺀 나머지를 반영하여 au, ab에 더합니다. 소수점 아래 부분인 ab보다 ty가 크다면 tn에서 1을 빼어 계산합니다.


    tn을 빈 문자열로 초기화합니다.

    br(0으로 나누어떨어짐) 이 걸려있으면 실행하지 않습니다. 그러므로 전체적으로 조건을 !br로 둔 다음 계산을 진행합니다.
    tw, tx, ty를 정의하고 처리하는 과정은 앞자리에서 몫을 찾는 과정과 동일합니다. 앞의 part 1에서 이미 au, ab를 정수로 만들었으므로 여기에 au, ab를 정수로 만드는 처리를 할 필요가 없습니다.

    ty를 정수로 바꾸는 과정을 아래 if 조건문으로 병합합니다.


    앞에서 계산된 tz의 값을 tw에 더한 다음 tw를 문자열로 바꿉니다. 그리고 tm에 문자열로 바꾼 tw을 더합니다.

    au와 ab가 모두 0이 될 때 br를 true로 정의합니다.

    어느 자릿수부터 br가 true로 되면 이후 자릿수 옮겨 몫을 구하는 과정이나 나머지를 정리하는 과정을 더 이상 할 필요가 없습니다.
    au, ab를 문자열로 다시 바꾸고 처리하는 과정은 동일합니다.

    ps를 au 자릿수가 18이 되었을 때 true가 되는 논리값으로 정의합니다.



    이후부터 과정은 동일합니다. 많아야 소수점 위 36자리, 소수점 아래 36자리 모두를 쓰면 72개이므로 총 72회(for i=0 to i=71)를 진행합니다.























































































































































































































































































    tn을 빈 문자열로 초기화하고 변수 ts를 가져옵니다. 마지막 72회까지 몫을 구하는 계산을 했음에도 불구하고 나머지가 나누어떨어져 0이 되지 않는다면 tn을 "..."로, ts를 true로 바꿉니다.


    앞에 매겼던 ac와 bc로 판별식을 만듭니다. i=ac-bc로 둡니다. a의 가장 큰 자리와 b의 가장 큰 자리가 얼마나 차이나는가에 따라 몫에 매기는 소수점 위치가 달라집니다. i>=-35 (ac==-18이고 bc==17일 경우), i<=35 (ac==17이고 bc=-18일 경우)입니다.

    a에서 b를 나누면 몫을 10^i 의 자리부터 매기게 됩니다. 소수점 아랫부분까지 몫 기록이 이어지면 상관이 없겠으나, 몫이 소수가 아닌 정수로 기록될 때 실제 자릿수에 해당하는 길이보다 (금방 나누어떨어져) 몫이 짧게 기록되고 그치는 경우 남는 자리에 자동적으로 0을 채워주지 않게 됩니다. 이러면 수동으로 0을 채워주어야 하며, (i==0일 경우 10^0의 자리부터 몫을 기록하므로 10^1과 같거나 큰 자리부터 기록할 경우 곧) i>0일 때에만 의미가 있습니다.
    이를테면 4000/2를 계산하는 경우 몫이 "2"까지만 기록되며 뒤에 000은 수동으로 채워주어야 합니다.


    i가 18 이상 (18 이상 35 이하)이면 rs를 매길 수 있습니다. 몫을 적어놓은 문자열 tm의 0번 index에 들어가는 문자부터 i에서 18을 뺀 값의 index에 들어가는 문자까지를 rs로 두며, rs의 문자열 길이는 i-18+1 곧 i-17입니다.


    ps를 먼저 false로 초기화한 다음, i>=18 이 되(어 rs를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 ru로 두고, tm에서 ru를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 (i가 충분히 큰 값이 아니고) i가 0 이상 (0 이상 17 이하)인 수라면 ru를 매길 수 있으며 문자열의 길이는 i+1이 됩니다.


    i>=0이 되(어 ru를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 문자열 tm에서 18번째 자리까지를 rb로 두고, tm에서 rb를 오려낸 문자열을 tm으로 둡니다.

    ps가 false이고 i가 -18 이상 (-18 이상 -1 이하)이면 rb를 매길 수 있습니다.
    이 때 몫으로 문자열의 길이는 i+18+1 곧 i+19가 되며 그 앞부분은 0으로 채워집니다.
    몫으로 i+19개의 자리가 채워진다면, 몫 앞을 0으로 채우는 수량은 18에서 i+19를 뺀 -i-1이 됩니다.
    이것을 substr을 이용하여 (18자리 문자열인) pd의 substr로 채워보자면
    18에서 (-i-1)을 뺀 i+19 번부터 끝까지 해당하는 문자열로 채우면 됩니다.


    i>=-18이 되(어 rb를 매기)는 경우 ps를 true로 맞춥니다.

    ps가 true이면 rb와 같은 방법으로 ri를 매기고, tm을 다시 정의합니다.

    ps가 false이며 i가 -19 이하 (-36이상 -19 이하이나, i의 최소값은 -35)이면 ri를 매길 수 있습니다. rb와 같습니다.


    ri까지 몫을 기록했음에도 불구하고 여전히 몫이 남는다면 ... 처리를 하고 ts를 true로 바꿉니다. 단, 나눗셈이 나누어떨어지는 식의 경우 경고 코드 2번을 반환합니다.


    여기까지가 나눗셈의 계산과정입니다.

    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    (-3) / 7 = -0.428571428571428571428571428571428571...


  1. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.
    Case 1-1 : rb가 0 이상인 경우
    rb가 소수점 아래 자릿수를 초과하여 소수점 위의 수를 계산하게 생겼다면 ap=bp인 상황에서 rp>ap가 됩니다. rb는 첫 숫자가 1인 정수가 되므로 첫 숫자인 1을 삭제한 문자열로 정의합니다.

    rb가 소수점 아래 자릿수를 초과하지 않을 경우 rb를 다시 정의할 필요 없이 그대로 둡니다.



    Case 1-2 : rb가 음수인 경우 ru에서 1을 빌려옵니다. 1보다 작은 양수값에서 1보다 작은 양수값을 빼면 -1보다 작을 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    123456789012345678.901234567890123456
    + 789012345678901234.567890123456789012
    = 912469134691246913.469124691346912468

  2. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.
    Case 1-1 : rb가 0 이상인 경우
    rb가 소수점 아래 자릿수를 초과하여 소수점 위의 수를 계산하게 생겼다면 ap=bp인 상황에서 rp>ap가 됩니다. rb는 첫 숫자가 1인 정수가 되므로 첫 숫자인 1을 삭제한 문자열로 정의합니다.

    rb가 소수점 아래 자릿수를 초과하지 않을 경우 rb를 다시 정의할 필요 없이 그대로 둡니다.



    Case 1-2 : rb가 음수인 경우 ru에서 1을 빌려옵니다. 1보다 작은 양수값에서 1보다 작은 양수값을 빼면 -1보다 작을 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    123456789012345678.9012345678901234567
    + 789012345678901234.567890123456789012
    → 123456789012345678.901234567890123456 + 789012345678901234.567890123456789012
    = 912469134691246913.469124691346912468
    [경고]
    변수 a의 소수점 아래에 입력한 문구가 너무 많습니다. 소수점 아래 19번째 자리부터 입력된 문구는 무시됩니다.

  3. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    (-5) * 200 = -1000

  4. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    (-1) * (-5) = 5

  5. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.
    Case 1-1 : rb가 0 이상인 경우
    rb가 소수점 아래 자릿수를 초과하여 소수점 위의 수를 계산하게 생겼다면 ap=bp인 상황에서 rp>ap가 됩니다. rb는 첫 숫자가 1인 정수가 되므로 첫 숫자인 1을 삭제한 문자열로 정의합니다.

    rb가 소수점 아래 자릿수를 초과하지 않을 경우 rb를 다시 정의할 필요 없이 그대로 둡니다.



    Case 1-2 : rb가 음수인 경우 ru에서 1을 빌려옵니다. 1보다 작은 양수값에서 1보다 작은 양수값을 빼면 -1보다 작을 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1.1 + 0.1 = 1.2

  6. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.
    Case 1-1 : rb가 0 이상인 경우
    rb가 소수점 아래 자릿수를 초과하여 소수점 위의 수를 계산하게 생겼다면 ap=bp인 상황에서 rp>ap가 됩니다. rb는 첫 숫자가 1인 정수가 되므로 첫 숫자인 1을 삭제한 문자열로 정의합니다.

    rb가 소수점 아래 자릿수를 초과하지 않을 경우 rb를 다시 정의할 필요 없이 그대로 둡니다.



    Case 1-2 : rb가 음수인 경우 ru에서 1을 빌려옵니다. 1보다 작은 양수값에서 1보다 작은 양수값을 빼면 -1보다 작을 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1.123 + 0.877 = 2

  7. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.
    Case 1-1 : rb가 0 이상인 경우
    rb가 소수점 아래 자릿수를 초과하여 소수점 위의 수를 계산하게 생겼다면 ap=bp인 상황에서 rp>ap가 됩니다. rb는 첫 숫자가 1인 정수가 되므로 첫 숫자인 1을 삭제한 문자열로 정의합니다.

    rb가 소수점 아래 자릿수를 초과하지 않을 경우 rb를 다시 정의할 필요 없이 그대로 둡니다.



    Case 1-2 : rb가 음수인 경우 ru에서 1을 빌려옵니다. 1보다 작은 양수값에서 1보다 작은 양수값을 빼면 -1보다 작을 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1.123 + 0.878 = 2.001

  8. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.
    Case 3-1 : rb가 0 이하인 경우
    rb가 음수이면서 자릿수를 초과한 경우 ru에 -1을 빼고, rb의 음수기호(-)와 첫번째 숫자인 문자열 "1"을 뺀 문자열로 rb를 다시 정의합니다.

    rb가 자릿수를 초과하지 않은 경우 rp는 음수기호를 제외한 숫자 자릿수이므로 rb를 음수기호만을 뺀 문자열로 다시 정의합니다. 단, rb가 0이 되면 rp==1이 되므로 rb==0인 경우는 제외합니다.

    Case 3-2 : rb가 0보다 큰 경우. 소수점 아래 부분을 보면 -1보다 큰 음수값에서 -1보다 큰 음수값을 빼면 1보다 클 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.

    -0.xxxx 같이 (ru==0인데) 연산결과가 -1보다 큰 음수로 나오는 경우가 있으므로 ru 앞에 음수 기호를 제거하고 ns에 "-"를 줍니다.


    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1.333 - 4.354 = -3.021

  9. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.
    Case 3-1 : rb가 0 이하인 경우

    Case 3-2 : rb가 0보다 큰 경우. 소수점 아래 부분을 보면 -1보다 큰 음수값에서 -1보다 큰 음수값을 빼면 1보다 클 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.
    ru<=-1이므로 ru+1를 해도 최대 0이 됩니다.

    rb>0에서 rb은 음수(계산결과)의 음수(마이너스값이 줄어듦)이므로 rb의 자릿수인 rp만큼 10을 제곱한 값(tv)에서 rb을 값으로 rb를 재정의합니다. 그러면 rb는 양수이지만 계산결과인 음수에 맞춘 값이 됩니다. 그리고 rb를 다시 문자열로 변환합니다. 변환합니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.

    -0.xxxx 같이 (ru==0인데) 연산결과가 -1보다 큰 음수로 나오는 경우가 있으므로 ru 앞에 음수 기호를 제거하고 ns에 "-"를 줍니다.


    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    7.89 - 12.345 = -4.455

  10. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.
    Case 1-1 : rb가 0 이상인 경우


    Case 1-2 : rb가 음수인 경우 ru에서 1을 빌려옵니다. 1보다 작은 양수값에서 1보다 작은 양수값을 빼면 -1보다 작을 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.

    소수점 아래 자릿수인 ap만큼 10을 제곱한 값(tv)을 rb에서 증가시켜 rb를 재정의합니다. 그러면 rb는 양수가 됩니다. 그리고 rb를 다시 문자열로 변환합니다.


    정리과정을 끝냈으면 ru를 string으로 변환합니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1 - 0.000000000000000001
    = 0.999999999999999999


  1. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.
    Case 2-1 : rb가 0 이상인 경우
    rb가 양수이면서 rb가 자릿수를 초과한 경우 rb는 첫 숫자가 1인 정수가 되므로 첫 숫자인 1을 삭제한 문자열로 정의합니다.

    ru를 string으로 변환합니다.


    Case 2-2 : rb가 음수인 경우


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.

    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    0.999999999999999999
    + 0.000000000000000001
    = 1

  2. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.
    만약 소수점 아래를 계산한다면 자릿수를 똑같이 맞춰야 의미가 있으므로, 자릿수가 다른 경우 자릿수가 같게 만드는 과정을 먼저 거칩니다. 이를테면 a의 소수점 자릿수가 b의 소수점 자릿수보다 많으면 b뒤에 0을 더 추가하는 방식으로 변경합니다. b 자체가 정수여도 앞에 (소수점이 없을 경우) 이미 bb="", bp=0+0으로 초기화했으므로 동작될 것입니다.
    소수점 아래 최대 18자리까지의 수를 취급하므로 최대 18칸 차이가 나게 됩니다.
    ap>bp에서 ap-bp>0이 됩니다. ap-bp는 곧 ap가 bp보다 몇 칸만큼 더 많은지를 나타냅니다.


    반대로 b의 소수점 자릿수가 많은 경우도 있습니다.


    위의 과정을 거치게 되면 소수점 아래 최대 자릿수를 똑같이 맞춘 상태에서 계산하게 되므로 ap==bp가 됩니다.

    a가 음수인 경우 소수점 아래 값은 순 숫자만 표기된 상태이므로 양수 취급으로 되지 않게 소수점 아래 값인 ab에 음수 표기를 남깁니다.

    마찬가지로 b가 음수인 경우 b의 소수점 아래 값은 음수이므로 소수점 아래 값인 bb에 음수 표기를 남깁니다. 10을 소수점 아래 자릿수만큼 제곱한 값으로 저장합니다.


    이때 rb를 계산합니다.



    소수점 아래끼리 더한 자릿수가 얼마나 되는지 보기 위해 rb를 문자열로 바꿉니다.
    이 때 rb가 0이 아닐 경우에만 문자열로 변환합니다.

    문자열로 된 rb의 길이를 rp로 정의합니다.


    rb가 음수이면 rb의 첫번째(0번 index)의 문자열에는 마이너스(-)가 들어갑니다. 이 때는 rp를 rb의 마이너스 문자열을 세지 않은 자릿수가 되도록 앞에서 정의했던 rb.length에서 1만큼 줄여 정의합니다. ap, bp는 마이너스를 붙이기 전에 값이 고정되어 있으므로 rp처럼 줄일 필요가 없습니다.


    ru값이 어떤지 보고 각 경우 rb값이 어떠한가에 따라 rb만 정리하거나 rb와 ru 모두 정리합니다.
    중복 처리를 막기 위해 초기화된 ps 변수 하나를 가져옵니다.

    소수점 아래 값의 부호와 소수점 위의 값의 부호가 서로 다른 경우 계산을 하기 위해 값을 하나 정의합니다.



    Case 1 : ru가 0보다 큰 경우
    ru는 정수이므로 ru가 0보다 크면 곧 ru는 1 이상의 정수이며, 1 이상이면 a+b 또는 a-b가 양수+음수 꼴이 되더라도 소수점 아래 정리를 하면 됩니다. rb를 정리하는 과정에서 ru에서 1을 빌려오거나 ru에 1이 더해질 수도 있습니다. 앞에서 rb를 string으로 바꿨으므로 +rb를 다룹니다.


    Case 2 : ru가 0인 경우 ru가 0이 되면 rb의 값이 양수인지 음수인지에 따라 달라집니다.


    Case 3 : ru가 0보다 작은 경우. 곧 -1 이하인 음수가 되는 경우.
    Case 3-1 : rb가 0 이하인 경우

    Case 3-2 : rb가 0보다 큰 경우. 소수점 아래 부분을 보면 -1보다 큰 음수값에서 -1보다 큰 음수값을 빼면 1보다 클 수 없으며, 소수점 아래 자릿수가 초과되지 않습니다.
    ru<=-1이므로 ru+1를 해도 최대 0이 됩니다.

    rb>0에서 rb은 음수(계산결과)의 음수(마이너스값이 줄어듦)이므로 rb의 자릿수인 rp만큼 10을 제곱한 값(tv)에서 rb을 값으로 rb를 재정의합니다. 그러면 rb는 양수이지만 계산결과인 음수에 맞춘 값이 됩니다. 그리고 rb를 다시 문자열로 변환합니다. 변환합니다.

    정리과정을 끝냈으면 ru를 string으로 변환합니다.

    -0.xxxx 같이 (ru==0인데) 연산결과가 -1보다 큰 음수로 나오는 경우가 있으므로 ru 앞에 음수 기호를 제거하고 ns에 "-"를 줍니다.


    여기까지가 소수점 아래 자릿수 숫자들의 계산과정입니다.

    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.


    +"000100"을 숫자로 바꾸면 100이 되는 문제가 있습니다. 이처럼 소수점 아래 자릿수를 연산한 결과를 문자열로 바꿨을 때 기존 소수점 아래 자릿수보다 작은 길이가 나오면 앞쪽에 0을 보충합니다.
    앞에서 ap,bp를 똑같이 맞췄으므로 ap를 가져옵니다. 자릿수가 모자랄 경우 0을 하나씩 보충합니다.


    앞에 0을 채웠다면 이제, 소수점 아래로 나오는 숫자를 보고 마지막에서부터 0이 나오면 한 자리씩 지우는 과정을 시작합니다.

    여기까지가 덧셈 또는 뺄셈연산의 계산과정이며 과정은 이후 rb 정리 과정으로 넘어갑니다.



    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1.000000000000000002
    - 2.000000000000000001
    = -0.999999999999999999

  3. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.

    rs를 정수로 바꿔 rs 앞에 있는 0들을 지운 다음 rs를 문자열로 바꿉니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    100000000000000000 * 100000000000000000
    = 10000000000000000000000000000000000

  4. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.

    rs를 정수로 바꿔 rs 앞에 있는 0들을 지운 다음 rs를 문자열로 바꿉니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    123456789012345678 * 789012345678901234
    = 97408930688616063755554032028766652

  5. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.

    rs를 정수로 바꿔 rs 앞에 있는 0들을 지운 다음 rs를 문자열로 바꿉니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.

    ps가 true일 때 19~36번째 자리인 ri까지 계산하므로 rp에 18을 더해야 하지만, 문자열 정리를 하기 위해 문자열의 index 번호를 다루고자 18을 더하는 작업은 뒤로 뻅니다.



    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.





    문자열 정리를 끝냈을 때 rp에 18을 더합니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    123456789012345678.901234567890123456
    * 789012345678901234.567890123456789012
    = 97408930688616064536749123600463663.409508352769482947759801506024265472

  6. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.

    rs를 정수로 바꿔 rs 앞에 있는 0들을 지운 다음 rs를 문자열로 바꿉니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.

    ps가 true일 때 19~36번째 자리인 ri까지 계산하므로 rp에 18을 더해야 하지만, 문자열 정리를 하기 위해 문자열의 index 번호를 다루고자 18을 더하는 작업은 뒤로 뻅니다.



    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.





    문자열 정리를 끝냈을 때 rp에 18을 더합니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    999999999999999999.999999999999999999
    * 999999999999999999.999999999999999999
    = 999999999999999999999999999999999998.000000000000000000000000000000000001

  7. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.

    rs를 정수로 바꿔 rs 앞에 있는 0들을 지운 다음 rs를 문자열로 바꿉니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.

    ps가 true일 때 19~36번째 자리인 ri까지 계산하므로 rp에 18을 더해야 하지만, 문자열 정리를 하기 위해 문자열의 index 번호를 다루고자 18을 더하는 작업은 뒤로 뻅니다.



    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.





    문자열 정리를 끝냈을 때 rp에 18을 더합니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    (-999999999999999999.999999999999999999)
    * (-999999999999999999.999999999999999999)
    = 999999999999999999999999999999999998.000000000000000000000000000000000001

  8. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.
    곱셈에서 0을 곱하면 0이 되므로, 곱셈의 경우 a 또는 b가 0이 될 때 계산 결과에 0을 반환합니다.

    나눗셈에서 나누는 수(b)가 0이 될 경우 오류를 반환하고 ps=true를 걸어 나눗셈 연산이 되지 않게 만듭니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.

    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    0 * 789012345678901234.567890123456789012
    = 0

  9. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.

    ps가 true일 때 19~36번째 자리인 ri까지 계산하므로 rp에 18을 더해야 하지만, 문자열 정리를 하기 위해 문자열의 index 번호를 다루고자 18을 더하는 작업은 뒤로 뻅니다.



    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.





    문자열 정리를 끝냈을 때 rp에 18을 더합니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    100000000000000000.000000001
    * 0.00000000000005678
    = 5678.00000000000000000000005678

  10. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.
    곱셈에서 0을 곱하면 0이 되므로, 곱셈의 경우 a 또는 b가 0이 될 때 계산 결과에 0을 반환합니다.

    나눗셈에서 나누는 수(b)가 0이 될 경우 오류를 반환하고 ps=true를 걸어 나눗셈 연산이 되지 않게 만듭니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.

    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    (-999999999999999999.9999999999999999999)
    * 0.0000000000000000009
    → (-999999999999999999.999999999999999999) * 0.0
    = 0
    [경고]
    변수 a와 b의 소수점 아래에 입력한 문구가 너무 많습니다. 소수점 아래 19번째 자리부터 입력된 문구는 무시됩니다.


  1. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    [오류] 변수 a의 소수점 윗자리에 올바르지 않은 문구가 입력되었습니다. (입력 오류)

  2. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    1.1 * 1.1 = 1.21

  3. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    [오류] 변수 a의 소수점 윗자리에 올바르지 않은 문구가 입력되었습니다. (입력 오류)

  4. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    [오류] 변수 a의 소수점 윗자리에 올바르지 않은 문구가, 변수 b의 소수점 아랫자리에 올바르지 않은 문구가 입력되었습니다. (입력 오류)

  5. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.
    곱셈에서 0을 곱하면 0이 되므로, 곱셈의 경우 a 또는 b가 0이 될 때 계산 결과에 0을 반환합니다.

    나눗셈에서 나누는 수(b)가 0이 될 경우 오류를 반환하고 ps=true를 걸어 나눗셈 연산이 되지 않게 만듭니다.
    error code 03 번 : 0으로 나눌 수 없습니다.

    나누는 수가 0이 아니면서 나눌 대상이 0이 될 경우 곱셈에서 0을 곱하는 것처럼 계산 결과에 0을 반환합니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.

    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    [오류] 0으로 나눌 수 없습니다. (입력 오류)

  6. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.

    ps가 true일 때 19~36번째 자리인 ri까지 계산하므로 rp에 18을 더해야 하지만, 문자열 정리를 하기 위해 문자열의 index 번호를 다루고자 18을 더하는 작업은 뒤로 뻅니다.



    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.





    문자열 정리를 끝냈을 때 rp에 18을 더합니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    0.111112222233333444테스트
    * 0.555556666677777888테스트
    → 0.111112222233333444 * 0.555556666677777888
    = 0.061729135811111209531233088874086272
    [경고]
    변수 a와 b의 소수점 아래에 입력한 문구가 너무 많습니다. 소수점 아래 19번째 자리부터 입력된 문구는 무시됩니다.

  7. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 발견되는 자리 번호가 ad이므로 ad+1번에 해당되는 자리부터 끝까지 표기합니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.
    a가 소수점 윗부분이 0이 되는 음수인 경우 "-0"으로 저장된 문자열은 정수값으로 바꿀 때 0이 되므로 ma앞에 -를 붙입니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.


    곱셈 및 나눗셈 연산과정을 봅니다.
    18자리 숫자로 입력할 수 있는 최대 정수는 999,999,999,999,999,999입니다.
    다행히 999,999,999,999,999,999*9=8,999,999,999,999,999,991 < long 한계치 9,223,372,036,854,775,807 이라서 a*각 자릿수로 덧셈해볼 수는 있습니다.

    a 또는 b가 음수가 될 경우 as 또는 bs 문자열은 "-" 기호가 붙으므로, 이것을 이용한 조건문을 하나 만들어 a와 b 둘의 부호가 서로 다를 경우 (a만 음수이거나 b가 음수일 경우) 계산 결과에 부호를 표시할 수 있게 만듭니다.

    a 또는 b가 음수가 될 경우 소수점 윗부분 문자열인 au 또는 bu에서 마이너스(-)를 제거합니다.



    나누는 자릿수에 맞춰 결과를 표시하고자 ac, bc를 자릿수를 나타내는 값으로 정의합니다.
    먼저 au는 앞에 적어놓은 0을 제거한 문자열이므로 +au>0인 경우 ac를 au의 문자열 길이에서 1을 뺀 값으로 정의합니다.

    (au, ab 둘다 0인 경우 앞에 처리하는 식이 있고, au, ab 둘 중 하나라도 0이 아닐 때) au가 0이라면 ab는 단순 정수값으로 옮겼을 때 0보다 큰 값이 나옵니다. 소수점 아래 처음으로 0이 아닌 수가 나오는 자릿수를 구한 다음 덧셈 연산에서 그 수의 역원이 되는 수를 ac로 정의합니다. 이를 구하고자 ab의 뒤에 0을 더 붙여 18자리 숫자로 만든 다음 정수로 바꾸어 구합니다.


    bc도 a와 같은 방법으로 정의합니다.


    a 또는 b값이 0이 되려면 au, ab 둘 다 0이 되거나 bu, bb 둘 다 0이 되어야 합니다. a 또는 b 값이 0일 경우 당연히 음수 부호가 표시되지 않습니다.

    곱셈과 나눗셈에서 a와 b 모두 0이 아닌 경우를 봅니다.
    곱셈계산에서 18자리씩 곱셈을 할 수 있도록 입력했던 a와 b의 문자열을 확장할 것입니다.

    a와 b 각각 소수점 윗자리와 소수점 아래자리의 문자열의 빈 공간을 0으로 채워 18자로 만듭니다.
    소수점 윗자리는 왼쪽에서 0을 채워나갑니다.
    +18자
    +18자

    소수점 아래자리는 오른쪽에서 0을 채웁니다. (ap, bp값은 보존됩니다.)
    +18자
    +18자


    여기까지 곱셈 또는 나눗셈에서 숫자를 초기화하는 과정입니다.

    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.
    곱셈은 18자리를 끊어서 계산합니다. 소수점 아래 18자리의 아래인 제19~36번 자리를 ri로 둡니다. 소수점 위 19~36번째 자리는 rs로 두어 ri, rb, ru, rs 순으로 계산합니다.
    소수점 위 18자리, 소수점 아래 18자리인 두 수를 곱하면 해당하는 자리별로 곱셈을 할 때 최대 (18+18)**2=1296회를 곱해야 합니다.

    앞으로 있을 계산은 다음과 같습니다.
    • ri를 더했더니 ri가 19자리 숫자로 넘치면 넘친 앞의 1자리를 rb로 넘깁니다.
    • rb가 19자리로 넘쳤다면 넘친 앞의 1자리를 ru로 넘깁니다.
    • ru가 19자리로 넘친다면 넘친 앞의 1자리를 rs로 넘깁니다.

    (rs는 상용로그로 보았을 때 log a<18, log b<18 에서 log (a*b) = log a + log b < 36이므로 19자리로 넘치지 않습니다.)
    문자열로 바꾸고 문자열을 쪼갠 다음 숫자로 바꾸는 과정입니다. 이를 if로 바꾸면 다음과 같습니다.

    변수 tv, tw, i, ps를 가져옵니다. tw는 0, tv는 1, i는 0, ps는 false으로 초기화 된 채로 있습니다. 연산 과정 중간중간에 마지막 자릿수를 보정하고자 10씩 곱하게 됩니다. ri에서 최대 18자리에서 1자리 수를 곱하면 19자리가 될 수 있으므로 곱셈할 때마다 19자리로 넘칠때마다 넘치는 숫자는 rb로 넘깁니다.
    ri부분을 합산합니다. ab*bb 의 절반을 처리합니다. (자릿수끼리 대입했을 때 처리되는 부분이 먼저 입력한 절반이 나중에 입력하는 절반보다 더 많지만, 편의상 절반이라고 적습니다.)


    rb부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bb의 나머지 절반 + au*bb의 절반), ab*bu의 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    ru부분을 합산합니다. substr(-1,0)은 빈 문자열 값이 나옵니다. (ab*bu의 나머지 절반 + au*bu의 절반), au*bb의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다.




















    rs부분을 합산합니다. au*bu의 나머지 절반을 처리합니다. i, tv, ps를 다시 초기화하고 시작합니다. 소수점 윗자리는 많아야 36자리이므로 rs에서 더 이상 넘치지 않습니다.



    여기까지가 곱셈에서 a*b 의 연산 과정이며 rb 정리 부분으로 넘어갑니다.

    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.


    곱셈연산에서 ri가 비어있지 않을 경우 ri와 rb를 문자열로 바꾼 다음 각각 왼쪽을 0으로 채웁니다.

    곱셈연산에서 ri가 비어있으나 rb가 비어있지 않을 경우 rb를 문자열로 바꾼 다음 rb의 왼쪽을 0으로 채웁니다.


    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.

    ps가 true일 때 19~36번째 자리인 ri까지 계산하므로 rp에 18을 더해야 하지만, 문자열 정리를 하기 위해 문자열의 index 번호를 다루고자 18을 더하는 작업은 뒤로 뻅니다.



    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.





    문자열 정리를 끝냈을 때 rp에 18을 더합니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,


    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    [오류] 변수 b에 소수점이 2개 이상 입력되었습니다. (입력 오류)

  8. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.


    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    00000000001 + 000001 → 1 + 1 = 2

  9. as : "a" value to string; bs : "b" value to string;
    al : "a" string length (integer); bl : "b" string length (integer)
    ad : "a" decimal point (integer); bd : "b" decimal point (integer);
    au : gold "a" upper value (string→integer); bu : "b" upper value (string→integer);
    ab : "a" below value (string→integer); bb : "b" below value (string→integer);
    ap : "a" # of places of decimal (for addition or subtraction);
    ac : a constant of "a" for division (integer);
    bp : "b" # of places of decimal (for addition or subtraction);
    bc : a constant of "b" for division (integer);
    0.303과 0.0303은 다른 수이므로 자리수가 다름을 표시할 용도
    ru : "result" upper value (integer→string); rb : "result" below value (integer→string);
    rp : "result" # of places of decimal (integer);
    rs : "result" suprerior value (integer→string); ri : "result" inferior value (integer→string);
    i : index;
    tu : temporary value 1 (integer); tv : temporary value 2 (integer);
    tw : temporary value 3 (integer); tx : temporary value 4 (integer→string);
    ty : temporary value 5 (integer); tz : temporary value 6 (integer);
    pd : padding with zeros. (string)
    ps : pass (logical); ts : not about gender test (logical) ; br : break (logical);
    ea : error code about "a" (integer); eb : error code about "b" (integer);
    wa : warning code about "a" (integer); wb : warning code about "b" (integer);
    ma : message about "a" (string); mb : message about "b" (string);
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    ns : negative sign for multiplication and division (string);

    값을 미리 정의하여 초기화합니다. 중간에 장난으로 계산에 사용되는 변수에 값을 부여한 채로 include 하더라도 이를 무시합니다.
    소수점이 존재하지 않을 경우 au 문자열 길이값을 ad로 정의합니다. au의 마지막 문자열 index는 ad-1이 됩니다.


    the seed에서 지원되는 long(integer)가 unsigned였으면 1844경까지 가서 충분히 19자리로 놀 수 있었는데, signed long이므로 922경까지 가능한 공간에서 18자리로 잘라내기를 합니다. (소수점 위 최대 18자리, 소수점 아래 최대 18자리)

    (반점(,)을 자동적으로 생략하고 들어가는 것은 나중에 생각하겠습니다.)

    a와 b 모두 입력되었을 때, br와 ts 변수를 이용하여 순차적으로 검사를 진행합니다. 도중 문제가 있으면 (br를 true로 반환하고) 오류 코드를 내도록 만듭니다. a를 먼저 보며, 소수점 윗부분을 먼저 본 다음 소수점 아랫부분을 봅니다.
    변수 tm와 tn을 가져와 유효성 검사를 실행합니다.
    먼저 소수점을 2개 이상 입력했음이 탐지된다면 오류코드 5번(이중 소수점 표기)을 반환합니다.
    소수점을 입력하면 indexOf와 lastIndexOf는 서로 다른 값을 가리키게 됩니다. 소수점을 입력하지 않았을 경우 indexOf와 lastIndexOf는 -1로 서로 같은 값을 가리키게 됩니다.


    문제가 없으면 au를 tm으로 복제하고 검사를 계속 합니다.
    앞자리가 마이너스(-)일 경우 이를 잘라냅니다. 이 때 소수점 윗자릿수가 넘치면 오류코드 1번(오버플로)를 반환합니다.


    의도적으로 00을 적어놓았을 수 있으므로 tm 앞에 숫자 1을 더 붙인 다음, 이를 값으로 바꾼 다음 다시 텍스트 값으로 바꾼 문자열을 tn으로 정의합니다. 중간에 숫자가 아닌 문구가 들어갔다면 숫자가 아닌 문구가 들어간 부분부터 값이 잘려 나오게 됩니다.
    숫자가 아닌 문구를 섞어넣었음이 탐지될 경우 오류코드 6번(소수점 윗자리 오류)을 반환합니다. (반점(,)도 걸릴 수 있습니다.)


    소수점 아래 부분을 검사합니다. 앞에서 소수점 개수를 검사했으므로 소수점 아래 부분에 점(.)이 더 이상 나올 수 없습니다.
    소수점 아래 입력한 자릿수가 19자리를 넘어가면 오류 대신 경고코드 1번(소수점 아래 자릿수 너무 많음)을 반환하고 소수점 아래 자릿수를 최대 18자리로 잘라냅니다. (이하 이상한 문구를 섞어도 이를 계산에 넣지 않게 됩니다.)


    앞에서 소수점 아래 자릿수를 18자 이하로 줄였습니다. 문자열에서 자릿수에 해당하는 index가 비어있다면 해당 문자열의 주소값은 null이 나옵니다. (예:"테스트"[3]==null) 숫자는 문자열 각 자릿수 문자열의 유니코드 값이 null이 아닌 이상 48 이상 57 이하이며, 이를 이용하여 소수점 아래 18자리에 대해 유효성 검사를 합니다.

    소수점 아래 자리에 입력한 부분이 문제가 있으면 오류코드 7번(소수점 아랫자리 오류)를 반환합니다.


    이와 같은 방법으로 b도 bu를 tm으로 복제하는 과정을 포함하여 유효성 검사를 실행합니다. 오류코드는 동일합니다.
    a와 b를 각각 진단해야 하므로 br를 false로 초기화합니다.





    유효성 검사가 종료되었으면 ts와 br, ps를 false로 초기화합니다 유효성 검사에 쓰인 tm과 tn 값을 빈 문자열 값으로 초기화합니다.


    입력한 소수점 아래에 입력한 값을 정리합니다. 이에 따라 ap, bp값도 다시 조정됩니다.
    ○○○○○○○○○□□□□○○□□○ 과 같이 9칸, 4칸, 2칸, 2칸, 1칸씩 그 정도를 보정하게 됩니다.











    그 다음 앞자리에 0만 여러 개 적어놓고 장난치는 사람이 있을까봐 au를 값으로 바꾼 다음 다시 문자열로 변환하여 앞자리에 있는 0들을 모두 삭제합니다. bu도 그렇게 둡니다.


    이 상태의 au를 ma로 저장하고 ab가 빈 문자열이 아니라면 ab도 ma에 저장합니다. 같은 방법으로 bu, bb을 mb에 저장합니다.



    덧셈과 뺄셈 계산과정을 적어봅니다.
    a과 b의 소수점 윗부분은 정수이므로 쉽게 계산할 수 있습니다.



    a와 b 모두가 정수이면 ap==0, bp==0이 되며, 이런 경우에는 소수점 아래 자릿수를 검산할 필요가 없습니다. a와 b 중 소수점 아래 자릿수가 있는 수가 있을 때에만 소수점 윗자리의 계산값이 얼마가 나오느냐를 보면서 소수점 아래의 자릿수를 정리하는 과정이 의미가 있습니다.


    a와 b 모두 정수인 경우 ap, bp는 모두 0이 되므로 ru만을 그대로 문자열로 바꾸면 되며 소수점 아래(rb)는 표기해야 할 필요가 없으므로 rb="", (소수점 아래 자릿수)rp=0을 반환합니다.


    rb==0인 경우 rb="", rp=0을 반환합니다.


    이제 rb=""이 아닌 경우 소수점 아래 숫자 정리를 합니다.
    rp를 rb의 문자열 길이로 다시 정의합니다.




    a와 b 모두 0이 아닌 경우에서 곱셈을 연산하는 과정입니다.


    a와 b 모두 0이 아닌 경우에서 나눗셈을 연산하는 과정입니다.


    연산이 끝났으면 표기된 숫자를 정리합니다.

    먼저 ru를 (곱셈연산에서 정수값으로 나올 수 있고, 나눗셈에서 몫이 1보다 작은 값이 나오는 경우같이 값을 부여하지 않았다면 초기화할 때 정의했던 정수 0인 채로 있으므로) 문자열로 바꿉니다.

    18자리씩 끊어 표기하므로 소수점 위 19~36번째 자리에 해당하는 rs값이 (가령 곱셈에서, 곱한 값을 더한 결과가) 0일 경우 rs를 빈 문자열로 바꿉니다. 이 때 ru를 정수로 바꿔 ru 왼쪽에 있는 0들을 지운 다음, ru를 문자열로 바꿉니다.


    계산과정에서 ru의 윗자리인 rs값이 0보다 클 경우, 1~18번째 자리인 ru에 빈 자리를 채우도록 ru의 왼쪽을 0으로 채웁니다.


    i보다 소수점 아래부분을 더 써내려가야 하는 상황이 아닌(나눗셈에서 ts가 false인) 경우에서, 소수점 아래 19~36번째 자리에 해당하는 ri값이 0일 경우 ri를 빈 문자열로 바꿉니다.
    이 때 ri와 rb가 모두 0일 경우 rb도 빈 문자열로 바꾸고 rp=0으로 둡니다.


    ri가 빈 문자열이 아닐 (+ri가 0보다 클) 때 true를 주는 논리값으로 ps를 정의합니다.




    !ts인 상황에서 ps가 true이면 rp를 ri의 길이로, 그렇지 않고 rb만 0이 아닌경우 rp를 rb의 길이로 정의합니다.




    !ts이면서 ri가 빈 문자열이 아닐 경우 ri의 오른쪽부터 붙은 "0"들을 모두 지웁니다.


    !ts이면서 이면서 ri가 빈 문자열일 경우, rb의 오른쪽에 붙은 "0"들을 모두 지웁니다,






    ts인 경우 rb, ri의 오른쪽 부분을 정리하지 않고 rp를 39로 정의합니다.




    rb 정리를 이것으로 종료합니다.

    error
    1 : 오버플로
    2 : 언더플로 (사용하지 않음)
    3 : 0으로 나눌 수 없음
    4 : 0으로 연산할 수 없음 (사용하지 않음)
    5 : 이중 소수점 표기
    6 : 소수점 윗부분 오류
    7 : 소수점 아랫부분 오류

    warning
    1 : 소수점 아래 입력한 자릿수가 너무 많음
    2 : 소수점 아래 표시하는 자릿수를 제한함 (나눗셈)
    3 : 소수점 아래 표시되는 자릿수가 너무 많음 (사용하지 않음)

    sa : searching a (logical); sb : searching b (logical); sf : searching f (logical);
    ps : pass (logical);
    ad : "a" decimal point of string variable 'ma' (integer);
    bd : "b" decimal point of string variable 'mb' (integer);
    md : displaying mode number (string→integer); ms : message for correction (string)
    tm : temporary string, or transaction message (string); tn : temporary string 2 (string);
    tx : temporary value 1 (integer); ty : temporary value 2 (integer); tz : temporary value 3 (integer);
    comment : comment (string);
    ru는 계산결과에서 소수점 위 자리이므로, dot(.)이 나오지 않습니다.
    0000000000 + 2 → 0 + 2 = 2


3. 문단[편집]

json={'a':'b', 'c':'d'}
json['a'] == 'b'
list = ['a', 'b']
list[1] == 'b'


../냥 < 볼드체. 단, ../뒤에 붙는 이름이 자기자신과 같은 이름이면 볼드체, 다른 이름(예 : ../냥냥, ../냥/냥)이면 볼드체가 아니다. 문서명이 '(상위문서명)/냥'일 경우에도 볼드체가 된다. 이 문서에는 상위 문서가 없으니 그냥 '냥' 으로 링크되는 듯 하다.
< 볼드체
냥#ㅁㄴㅇㄹ < 볼드체아님
문서:냥 < 볼드체아님
= 13
[include(틀:계산기, r=13)]
생각해보니까 그냥 r을 지정할 수도 있겠구나
123456789 + 1 = 123456790
123456789 - 1 = 123456788
123459 × 2 = 246918
123459 ÷ 2 = 61729.5

4. 그래프구상[편집]

x2x^2
#tk : thickness (px) ; wd : width (px)


5. 나무나무마크[편집]

  • todo: 리스트, 주석, 문단, 인용문?, 테이블? +(분류, 각주)느낌만내기
{{{#!wiki style="text-align: center"
{{{#!wiki style="margin: auto; max-width: 700px; border-radius: 12px; background: linear-gradient(to right, #00a69c, #28b472); overflow: hidden; word-break: keep-all" dark-style="background: linear-gradient(to right, transparent, #2e3033)"
{{{#!wiki style="display: flex; padding: 10px 0 15px; justify-content: center; align-items: center; gap: 10px"
'''{{{+5 [[나무위키|{{{#fff,#fff +5&#fff&linked}}}]]}}}[br]{{{#fff,#fff 둘러보기아님}}}'''}}}}}}
verified?{{{#!html <span style="font-family: Ionicons">&#xf149</span>}}}
[[냥|링크]]&[[깨지는 링크]]&[[https://namu.wiki/w/사용자:nyangx3|외부 링크]]
'''강조'''''기울임''--취소선--__밑줄__,,아래,,^^위^^
냥[br]냥[clearfix]d[ruby(글자,ruby=루비,color=red)][ruby(글자,ruby=루비루비)]sid
----
{{{#!wiki style="display: inline-block"
{{{#!wiki style="" dark-style="display: none"
[youtube(NNGd3uANaes, start=21)]폭력 장면이 포함되어 있어 일부 시청자에게 불쾌감을 줄 수 있습니다.}}}{{{#!wiki style="display: none" dark-style="display: block"
[youtube(YnSW8ian29w, start=0s)]genre: ''' ''Ado'' '''}}}}}}}}}

실제:
+5&#fff&linked
둘러보기아님

verified?
링크&깨지는 링크&외부 링크
강조기울임취소선밑줄아래

d글자(루비)글자(루비루비)sid

폭력 장면이 포함되어 있어 일부 시청자에게 불쾌감을 줄 수 있습니다.
genre: Ado




나무나무마크:






















































































































































































































































































둘러보기아님

verified?
&&
강조기울임취소선밑줄아래

d글자루비글자루비루비sid

폭력 장면이 포함되어 있어 일부 시청자에게 불쾌감을 줄 수 있습니다.
genre: Ado

둘러보기아님

verified?
&&
강조기울임취소선밑줄아래

d글자루비글자루비루비sid

폭력 장면이 포함되어 있어 일부 시청자에게 불쾌감을 줄 수 있습니다.
genre: Ado

6. 나무나무마크구상[편집]

  • 할거 > 분류

input=냥[[링크|냥]]냥[[https://namu.wiki/w/사용자:nyangx3|냥]]냥











화이트: 냥

다크: 냥

7. 나무나무마크구상2[편집]

  • 리터럴귀찮음 if folding syntax는 될리가없음

input={{{#!wiki style="text-align: center"<br>{{{+5 '''[[사용자:nyangx3/연습장|{{{#373a3c,#ddd 냥냥냥}}}]]'''}}}<br>{{{-1 [[고양이]]는 신이야}}}{{{#!wiki style="word-break: keep-all" dark-style="color: red"<br>{{{-3 별 이유 없이 오셨다면, 별 이유는 없고 사용자 문서에 별({{{#595c5f,#e0e0e0 {{{#!html <span style="font-family: Ionicons">&#xf4b2</span>}}}}}}) 한 번 눌러 주세요.}}}}}}}}}












































































































화이트:
'''[[사용자:nyangx3/연습장|
냥냥냥
]]'''

[[고양이]]는 신이야
별 이유 없이 오셨다면, 별 이유는 없고 사용자 문서에 별(
) 한 번 눌러 주세요.

다크:
'''[[사용자:nyangx3/연습장|
냥냥냥
]]'''

[[고양이]]는 신이야
별 이유 없이 오셨다면, 별 이유는 없고 사용자 문서에 별(
) 한 번 눌러 주세요.

8. 나무나무마크구상3[편집]



input='''강조'''''기울임''--취소선--__밑줄__,,아래,,^^위^^<br>----<br>








output: 강조기울임취소선밑줄아래


9. 나무나무마크구상4[편집]

ruby는 쉼표 붙여쓰기.

input=냥[br]냥[clearfix]d[ruby(글자,ruby=루비,color=red)][ruby(글자,ruby=루비루비)]sid




output: 냥
d글자루비[ruby(글자,ruby=루비루비)]sid

10. 나무나무마크구상5[편집]

동영상 매크로.
start, end는 숫자 입력해야 한다. 실제 나무마크에선 1s같이 뒤에 s를 붙인 형식도 되는데 다 만들고 나서 알게된 이유로 귀찮


input=[youtube(GrAchTdepsU, start=1, end=10000890890, width=640)][youtube(T2fjQrsKbAM, start=1, end=, width=640)]






































output:

11. ㅁㄴㅇㄹ[편집]

A
1-s
*




















































A
1-s
*





















































A
1-s
*




















































A
1-s
*




















































A
1-s
*


























































Mozilla/5.0 (compatible; Daum/1.0; +http://ws.daum.net/aboutkr.html) ok
Mozilla/5.0 (compatible; coccocbot-web/1.0; +http://help.coccoc.com/web) ok

12. include 문서 가져옴[편집]

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=32, uuid=2d701244-1d84-4716-8717-e07569140961)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





본 문서는 더시드위키의 검색(r32 판) 문서에서 가져왔습니다.
CCL BY 조항에 따라 검색 문서의 이전 역사를 확인할 수 있습니다.

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=32, UUID=2d701244-1d84-4716-8717-e07569140961, uuid=2d701244-1d84-4716-8717-e0756914096d)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





오류! : "uuid"와 "UUID" 둘 중 하나만 입력해 주세요. (uuid= 또는 UUID= 입력)

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=-1, UUID=2d701244-1d84-4716-8717-e07569140961)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





오류! : 가져온 문서의 "버전"(리비전 번호)의 숫자값을 입력해 주세요.

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=32, UUID=)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





오류! : 리비전을 나타내는 "uuid"의 값을 입력해 주세요. (uuid= 또는 UUID= 입력)

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=32, uuid=2d701244-1d84-4716-8717-e0756914096x)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





오류! : 올바르지 않은 UUID입니다. 입력한 UUID를 확인해주세요.

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=32, UUID=2d701244-1d84-4716-8717-e07569140961)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





본 문서는 더시드위키의 검색(r32 판) 문서에서 가져왔습니다.
CCL BY 조항에 따라 검색 문서의 이전 역사를 확인할 수 있습니다.

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=32, UUID=2d701244-1d84-4716-8717-e0756914096x)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





오류! : 올바르지 않은 UUID입니다. 입력한 UUID를 확인해주세요.

[include(틀:문서 가져옴/the seed, 위키=더, 문서명=검색, 버전=32, uuid=2d701244-1d84-4716-8717-e07569140961, UUID=2d701244-1d84-4716-8717-e07569140961)]
#if (위키==구버전)
##the seed 구버전 커스텀 전용. (Imitated Seed 라던지)

{{{#!if previous=true
}}}





오류! : "uuid"와 "UUID" 둘 중 하나만 입력해 주세요. (uuid= 또는 UUID= 입력)

[include(틀:isuuid, uuid=1dd4a127-1b8d-4788-8cea-9ff8b1ddd06e)]
1dd4a127-1b8d-4788-8cea-9ff8b1ddd06e는 uuid입니다.

[include(틀:isuuid, uuid=xdd4a127-1b8d-4788-8cea-9ff8b1ddd0xx)]
xdd4a127-1b8d-4788-8cea-9ff8b1ddd0xx는 uuid가 아닙니다.
[include(틀:isuuid, uuid=냥)]
냥는 uuid가 아닙니다.

13. method[편집]


  • 동작 o

substring() - javascript가 아니라 java이기에 substring(start, end)에서 start가 end보다 클 시 두 인덱스가 교환되지 않는다.
substr()
trim() - 매게변수로 넘겨주는 값은 기본적으로 공백이 제거되기에 딱히 쓸모x
startsWith(), endsWith()
length
indexOf(), lastIndexOf()
parseInt()
  • 동작 x

slice()
toLowerCase(), toUpperCase()
isEmpty(), isBlank()
replace(), replaceAll()[1] - ㅈㄴ아쉽다이게안되네
contains() - indexOf로 대체 가능
charAt() - substring(a, a+1)로 대체 가능 // a[정수]로 사용 가능
equals() - ==로 대체 가능
compareTo() (사전순 비교)
subSequence() - substring()와 같음.
strip() (유니코드 공백까지 제거)
concat() (뒤에 문자열 추가) - 그냥 + 쓰면 됨
matches() (정규식 일치 여부 확인) - ㅈㄴ아쉽다이게안되네2
repeat() (문자열을 지정된 횟수만큼 반복)
[1] 정규식에 맞는 모든 부분을 교체.
toString() 가능
parseInt() x

14. [편집]

11+2 =

this['v1'] == 1

this['v1'] == 11

this['v2'] == 2

11+2