조회 수 28144 추천 수 0 댓글 0
Atachment
첨부 '2'
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
(20061116 에 업데이트 한 내용)
calc_linux_tree.c 를 make 버전으로 수정했음
출력 시 줄바꿈 되는 부분 수정(입력 값에서 줄바꿈 부분 없앰)

업로드 파일 설명..

[calc_console.zip]
이진 트리를 사용한 계산기(링스리스트)
사칙연산과 괄호에 대한 우선순위 적용
리눅스 콘솔 환경

[calc_web.zip]
위의 콘솔 환경을 웹 버전으로 바꾼것..
기능은 같음 ㅋㅋ
old/new 두 가지가 있음

new - 우선 순위 연산계산기..
https://www.hooni.net/app/calc/new/index.cgi

old - 웹 프로그래밍 테스트로 만든 간단한.. ㅋㅋ
https://www.hooni.net/app/calc/old/index.html


링크리스트(Linked List)로 구현한 스택(Stack)과 2진 트리(Tree) 자료구조를 이용한 계산기
2진 트리 자료구조로 구현되어 전위, 중위, 후외  표기법 모두 표현할 수 있음!! ㅋㅋ
웹버전과 일반 콘솔 버전이 포함됨..


(2*(3+6/2)+2)/4+3

위와 같은 수식을 해석해서 계산해주는 스택을 이용한 계산기 입니다.

연산자의 우선순위를 고려한 수식표현방법에 대해 알아봅니다.
수식을 표현할때 흔히 사용되는 방법은 중위표기법 입니다.
하지만 컴퓨터는 이를 이해하기 힘듭니다.
컴퓨터가 이해하기 쉬운 구조로 바꾸기 위해 중위표기법을
후위표기법으로 바꿔야 합니다.
※C로배우는 알고리즘(세화 - 이재규)에 잘 소개되어 있습니다.

일단 구현범위를 잡습니다.
연자자는 4칙연산만 정의되도록합니다.( +, -, *, / )
연산자 마다 우선순위를 부여하자
우선순위가 높을수록 큰수를 부여
예) +, - 는 1 을 부여하고 *, /는 2를 부여, 괄호 ( 는 0을 부여

알고리즘
1. '('를 만나면 스택에 푸시
2. ')'를 만나면 스택에서 '('가 나올때까지 팝하여 출력하고 '('는 버림
3. 연산자를 만나면 스택에서 그 연산자보다 낮은 우선순위의 연산자를
   만날 때까지 팝하여 출력한 후 자신을 푸시
4. 피연산자는 그냥 출력
5. 모든 입력이 끝나면 스택에 있는 연산자들을 모두 팝하여 출력.

아래의 예를 보겠습니다.

(2*(3+6/2)+2)/4+3
문자출력스택(상->하)설명
(('('는 푸시
22(피연산자 출력
*2* ('*'가 '('보다 우선순위 높음
(2( * ('('는 푸시
32 3( * (피연산자는 출력
+2 3+ ( * ('+'가 '('보다 우선순위 높음
62 3 6+ ( * (피연산자는 출력
/2 3 6/ + ( * ('/'가 '+'보다 우선순위 높음
22 3 6 2/ + ( * (피연산자는 출력
)2 3 6 2 / +* ('('까지 팝하여 출력, ')'는 무시
+2 3 6 2 / + *+ ('*'는 '+'보다 높으므로 팝
22 3 6 2 / + * 2+ (피연산자는 출력
)2 3 6 2 / + * 2 ++ ('('까지 팝하여 출력
/2 3 6 2 / + * 2 +/연산자 푸시
42 3 6 2 / + * 2 + 4/피연산자 출력
+2 3 6 2 / + * 2 + 4 /+'/'는 '+'보다 높으므로 팝
32 3 6 2 / + * 2 + 4 / 3+피연산자는 출력
2 3 6 2 / + * 2 + 4 / 3 +끝이므로 모두 팝
?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
1077 Develop [c] RSA 암호화 구현(gmp 라이브러리 활용) file hooni 2016.10.03 1005
1076 PPT 삼성페이(Samsung Pay) 구조 file hooni 2016.09.09 1010
1075 Develop XE Core 1.8.18 본문 작성시 태그(html) 사라지는 버그 file hooni 2016.04.21 1012
1074 Develop [js] AngularJS 란? file hooni 2015.11.26 1015
1073 System/OS [mac] How to uninstall MySQL on Mac OS. hooni 2017.11.08 1028
1072 System/OS [virtualbox] VirtualBox에 Ubuntu 설치하기 file hooni 2019.11.22 1054
1071 Develop [ios] 로컬에 있는 JS 파일 웹뷰에서 동적으로 실행하기 hooni 2015.02.10 1064
1070 Develop [ios] 오브젝티브C→스위프트, 코드 변환 손쉽게 file hooni 2015.08.07 1068
1069 Develop [ios] Xcode에서 특정 파일만 ARC 따로 설정하는 방법 file hooni 2017.03.29 1069
1068 Develop [android] 딜레이를 구현하기 위한 꼼수 hooni 2016.11.24 1071
1067 Develop [ios] APNS, Remote Push 수신 시점에서 앱의 3가지 실행 상태 hooni 2018.10.19 1078
1066 Develop [js] 스크롤 이벤트 막기 hooni 2015.04.14 1080
1065 Develop [ubuntu] 우분투 18.04에 PHP5 설치하기 hooni 2020.11.14 1085
1064 Etc EBS [수학영역] 미적분과 통계 기본 - 정규분포의 의미와 특징은? hooni 2015.04.20 1089
1063 System/OS [펌] 마이크로서비스, 모노리포, SRE, ... 덮어놓고 구글 따라하면 안 되는 기술들 file hooni 2020.10.15 1094
1062 Develop [ios] Xcode의 디버그 모드에서 콜스택 file hooni 2015.01.03 1102
Board Pagination Prev 1 5 6 7 8 9 ... 74 Next
/ 74