Skip to content
조회 수 11774 추천 수 0 댓글 0


Prev이전 문서

Next다음 문서

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


Prev이전 문서

Next다음 문서

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


Pseudocode is a kind of structured english for describing algorithms. It allows the designer to focus on the logic of the algorithm without being distracted by details of language syntax.  At the same time, the pseudocode needs to be complete.  It describe the entire logic of the algorithm so that implementation becomes a rote mechanical task of translating line by line into source code.

In general the vocabulary used in the pseudocode should be the vocabulary of the problem domain, not of the implementation domain.  The pseudocode is a narrative for someone who knows the requirements (problem domain) and is trying to learn how the solution is organized.  E.g.,

Extract the next word from the line (good)
set word to get next token (poor)

Append the file extension to the name (good)
name = name + extension (poor)

FOR all the characters in the name (good)
FOR character = first to last (ok)

Note that the logic must be decomposed to the level of a single loop or decision. Thus "Search the list and find the customer with highest balance" is too vague because it takes a loop AND a nested decision to implement it. It's okay to use "Find" or "Lookup" if there's a predefined function for it such as String.indexOf().

Each textbook and each individual designer may have their own personal style of pseudocode. Pseudocode is not a rigorous notation, since it is read by other people, not by the computer. There is no universal "standard" for the industry, but for instructional purposes it is helpful if we all follow a similar style. The format below is recommended for expressing your solutions in our class.

The "structured" part of pseudocode is a notation for representing six specific structured programming constructs: SEQUENCE, WHILE, IF-THEN-ELSE, REPEAT-UNTIL, FOR, and CASE. Each of these constructs can be embedded inside any other construct. These constructs represent the logic, or flow of control in an algorithm.

It has been proven that three basic constructs for flow of control are sufficient to implement any "proper" algorithm.

SEQUENCE is a linear progression where one task is performed sequentially after another.
WHILE is a loop (repetition) with a simple conditional test at its beginning.
IF-THEN-ELSE is a decision (selection) in which a choice is made between two alternative courses of action.

Although these constructs are sufficient, it is often useful to include three more constructs:

REPEAT-UNTIL is a loop with a simple conditional test at the bottom.
CASE is a multiway branch (decision) based on the value of an expression. CASE is a generalization of IF-THEN-ELSE.
FOR is a "counting" loop.


Sequential control is indicated by writing one action after another, each action on a line by itself, and all actions aligned with the same indent. The actions are performed in the sequence (top to bottom) that they are written.

Example (non-computer)

Brush teeth
Wash face
Comb hair
Smile in mirror


READ height of rectangle
READ width of rectangle
COMPUTE area as height times width

Common Action Keywords

Several keywords are often used to indicate common input, output, and processing operations.
Initialize: SET, INIT


Binary choice on a given Boolean condition is indicated by the use of four keywords: IF, THEN, ELSE, and ENDIF. The general form is:

IF condition THEN
sequence 1
sequence 2

The ELSE keyword and "sequence 2" are optional. If the condition is true, sequence 1 is performed, otherwise sequence 2 is performed.


IF HoursWorked > NormalMax THEN
Display overtime message
Display regular time message


The WHILE construct is used to specify a loop with a test at the top. The beginning and ending of the loop are indicated by two keywords WHILE and ENDWHILE. The general form is:

WHILE condition

The loop is entered only if the condition is true. The "sequence" is performed for each iteration. At the conclusion of each iteration, the condition is evaluated and the loop continues as long as the condition is true.


WHILE Population < Limit
Compute Population as Population + Births - Deaths


WHILE employee.type NOT EQUAL manager AND personCount < numEmployees
INCREMENT personCount
CALL employeeList.getPerson with personCount RETURNING employee


A CASE construct indicates a multiway branch based on conditions that are mutually exclusive. Four keywords, CASE, OF, OTHERS, and ENDCASE, and conditions are used to indicate the various alternatives. The general form is:

CASE expression OF
condition 1 : sequence 1
condition 2 : sequence 2
condition n : sequence n
default sequence

The OTHERS clause with its default sequence is optional. Conditions are normally numbers or characters

indicating the value of "expression", but they can be English statements or some other notation that specifies the condition under which the given sequence is to be performed. A certain sequence may be associated with more than one condition.


        CASE  Title  OF
                Mr      : Print "Mister"
                Mrs     : Print "Missus"
                Miss    : Print "Miss"
                Ms      : Print "Mizz"
                Dr      : Print "Doctor"


        CASE  grade  OF
                A       : points = 4
                B       : points = 3
                C       : points = 2
                D       : points = 1
                F       : points = 0


This loop is similar to the WHILE loop except that the test is performed at the bottom of the loop instead of at the top. Two keywords, REPEAT and UNTIL are used. The general form is:

UNTIL condition

The "sequence" in this type of loop is always performed at least once, because the test is peformed after the sequence is executed. At the conclusion of each iteration, the condition is evaluated, and the loop repeats if the condition is false. The loop terminates when the condition becomes true.


This loop is a specialized construct for iterating a specific number of times, often called a "counting" loop.  Two keywords, FOR and ENDFOR are used. The general form is:

FOR iteration bounds

In cases where the loop constraints can be obviously inferred it is best to describe the loop using problem domain vocabulary.


FOR each month of the year (good)
FOR month = 1 to 12 (ok)

FOR each employee in the list (good)
FOR empno = 1 to listsize (ok)


The constructs can be embedded within each other, and this is made clear by use of indenting. Nested constructs should be clearly indented from their surrounding constructs.


SET total to zero
READ Temperature
IF Temperature > Freezing THEN
    INCREMENT total
UNTIL Temperature < zero
Print total

In the above example, the IF construct is nested within the REPEAT construct, and therefore is indented.


Use the CALL keyword. For example:

CALL AvgAge with StudentAges
CALL Swap with CurrentItem and TargetItem
CALL Account.debit with CheckAmount
CALL getBalance RETURNING aBalance
CALL SquareRoot with orbitHeight RETURNING nominalOrbit


        WHEN exception type
            statements to handle exception
        WHEN another exception type
            statements to handle exception

Sample Pseudocode


FOR X = 1 to 10

    FOR Y = 1 to 10
        IF gameBoard[X][Y] = 0
            Do nothing
            CALL theCall(X, Y) (recursive method)
            increment counter                 
        END IF


Set moveCount to 1
FOR each row on the board
    FOR each column on the board
        IF gameBoard position (row, column) is occupied THEN
            CALL findAdjacentTiles with row, column
            INCREMENT moveCount
        END IF

(Note: the logic is restructured to omit the "do nothing" clause)

"Not So Good"

FOR all the number at the back of the array
    SET Temp equal the addition of each number
    IF > 9 THEN
        get the remainder of the number divided by 10 to that index
        and carry the "1"
    Decrement one
Do it again for numbers before the decimal

"Good Enough (not perfect)"

SET Carry to 0
FOR each DigitPosition in Number from least significant to most significant

    COMPUTE Total as sum of FirstNum[DigitPosition] and SecondNum[DigitPosition] and Carry  

    IF Total > 10 THEN
        SET Carry to 1
        SUBTRACT 10 from Total
        SET Carry to 0
    END IF

    STORE Total in Result[DigitPosition]


IF Carry = 1 THEN
    RAISE Overflow exception


"Pretty Good"  This example shows how pseudocode is written as comments in the source file. Note that the double slashes are indented.

public boolean moveRobot (Robot aRobot)
    //IF robot has no obstacle in front THEN
        // Call Move robot
        // Add the move command to the command history
        // RETURN true
        // RETURN false without moving the robot
    //END IF

Example Java Implementation

  • source code statements are interleaved with pseudocode.
  • comments that correspond exactly to source code are removed during coding.

public boolean moveRobot (Robot aRobot)
    //IF robot has no obstacle in front THEN
    if (aRobot.isFrontClear())
        // Call Move robot
        // Add the move command to the command history
        return true;
    else // don't move the robot
        return false;
    }//END IF

Document History

Date Author Change
Added Exception Handling and more examples
2/21/03 JD Added "problem domain vocabulary" paragraph.
Modified FOR loop explanation.

출처: www.csc.calpoly.edu/~jdalbey/SWE/pdl_std.html


출처 : http://bart7449.tistory.com/10


공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.17 828858
1048 경제 우리나라최초의 신용카드회사는요? file JaeSoo 2012.09.14 3411
1047 소프트웨어 MRTG(Multi Router Traffic Grapher) 설치하기 file JaeSoo 2012.09.14 3163
1046 네트워크 3G 모바일 네트워크의 이해 JaeSoo 2012.09.14 4728
1045 사무 소프트웨어 씽크프리(thinkfree) 그 정체를 밝혀라! file JaeSoo 2012.09.14 5114
1044 기타 행정안전부가 각 부처 소관 복지사업 실시내역을 취합ㆍ관리하는 데이터베이스를 구축할 수 있는지 여부(「전자정부법」 제54조제2항 등 관련) JaeSoo 2012.09.12 3681
1043 육아,교육 [제대로 된 ‘性교육’이 답이다]<下> 성범죄 예방 교과서 만들자 file JaeSoo 2012.09.12 4013
1042 육아,교육 [제대로 된 ‘性교육’이 답이다]<上> 사실상 손놓은 학교 교육 file JaeSoo 2012.09.12 4142
1041 육아,교육 "혼자있을때택배오면?" 일상속 매뉴얼을 가르쳐라 file JaeSoo 2012.09.12 6619
1040 사무 소프트웨어 엑셀에서 행과 열을 바꾸어 복사하기 file JaeSoo 2012.09.11 7556
1039 경제 '12년9월부터 신용카드 누적사용액 문자로 알려준다. file JaeSoo 2012.09.11 5474
1038 육아,교육 엄마를 배우게 하라 [LEARNING MOM] file JaeSoo 2012.09.11 3523
1037 하드웨어 인텔 E3200 울프데일 듀얼코어 CPU를 싱글코어로 설정하여 전력소모 줄이기 file JaeSoo 2012.09.11 5747
1036 보안 SIS 정보보호전문가 (Specialist for Information Security) file JaeSoo 2012.09.10 4508
1035 논문 Algorithms & Pseudo-Code JaeSoo 2012.09.08 5005
» 논문 슈도(Pseudo) 코드 작성의 표준화 JaeSoo 2012.09.08 11774
1033 논문 Pseudo Code 작성법 JaeSoo 2012.09.08 5587
1032 웹 프로그래밍 apache의 httpd.conf 설정 팁 JaeSoo 2012.09.08 3299
1031 웹 프로그래밍 apache httpd.conf 설정 및 설명 JaeSoo 2012.09.08 3213
1030 웹 프로그래밍 Window에서 아파치+톰캣 연동시 httpd.exe 메모리 누수 관련 JaeSoo 2012.09.08 3901
1029 논문 기술 논문 작성 file JaeSoo 2012.09.08 4879
Board Pagination Prev 1 ... 68 69 70 71 72 73 74 75 76 77 ... 125 Next
/ 125


■ 즐겨찾기 - 가족
JAESOO's HOMEPAGE YOUNGAE's HOMEPAGE 장여은 홈페이지 장여희 홈페이지 장여원 홈페이지

■ 즐겨찾기 - 업무
알리카페 홀릭 숭실대 컴퓨터 통신연구실 (서창진) 말레이시아 KL Sentral 한국인 GuestHouse

■ 즐겨찾기 - 취미
어드민아이디 유에코 사랑회 아스가르드 좋은사람/나쁜사람 JServer.kr 제이서버 메타블로그 재수 티스토리

■ 즐겨찾기 - 강의, 커뮤니티
재수 강의 홈페이지 한소리 VTMODE.COM 숭실대 인공지능학과 숭실대 통신연구실

PageViews   Today : 907   Yesterday : 5,379   Total : 61,612,701  /  Counter Status   Today : 367   Yesterday : 986   Total : 3,403,278
Site Info   Member : 1,399  /  Total documents : 7,231   New documents : 0  /  Total comments : 521

design by by JAESOO.com

sketchbook5, 스케치북5

sketchbook5, 스케치북5

나눔글꼴 설치 안내

이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소