RadarURL

논문
2012.09.09 08:47

Algorithms & Pseudo-Code

조회 수 5028 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

Definition of Algorithm (after Al Kho-war-iz-mi a 9th century Persian mathematician) - an ordered sequence of unambiguous and well-defined instructions that performs some task and halts in finite time 

Let's examine the four parts of this definition more closely

  1. an ordered sequence means that you can number the steps (it's socks then shoes!)
  2. unambiguous and well-defined instructions means that each instruction is clear, do-able, and can be done without difficulty
  3. performs some task
  4. halts in finite time (algorithms terminate!)

Algorithms can be executed by a computing agent which is not necessarily a computer.


Three Catagories of Algorithmic Operations

Algorithmic operations are ordered in that there is a first instruction, a second instruction etc. However, this is not enough. An algorithm must have the ability to alter the order of its instructions. An instruction that alters the order of an algorithm is called a control structure

Three Categories of Algorithmic Operations:

  1. sequential operations - instructions are executed in order
  2. conditional  ("question asking") operations - a control structure that asks a true/false question and then selects the next instruction based on the answer
  3. iterative operations (loops) - a control structure that repeats the execution of a block of instructions

Unfortunately not every problem or task has a "good" algorithmic solution. There are 

  1. unsolvable problems - no algorithm can exist to solve the problem (Halting Problem)
  2. "hard" (intractable) problems - algorithm takes too long to solve the problem (Traveling Salesman Problem)
  3. problems with no known algorithmic solution

How to represent algorithms?

  1. Use natural languages
    • too verbose
    • too "context-sensitive"- relies on experience of reader
  2. Use formal programming languages
    • too low level
    • requires us to deal with complicated syntax of programming language
  3. Pseudo-Code - natural language constructs modeled to look like statements available in many programming languages

Pseudo-Code is simply a numbered list of instructions to perform some task. In this course we will enforce three standards for good pseudo code

  1. Number each instruction. This is to enforce the notion of an ordered sequence of ... operations. Furthermore we introduce a dot notation (e.g. 3.1 come after 3 but before 4) to number subordinate operations for conditional and iterative operations
  2. Each instruction should be unambiguous (that is the computing agent, in this case the reader, is capable of carrying out the instruction) and effectively computable (do-able).
  3. Completeness. Nothing is left out.

Pseudo-code is best understood by looking at examples. Each example below demonstrates one of the control structures used in algorithms : sequential operations,  conditional operations, and iterative operations. We also list all variables used at the end of the pseudo-code.


Example #1 - Computing Sales Tax : Pseudo-code the task of computing the final price of an item after figuring in sales tax. Note the three types of instructions: input (get), process/calculate (=) and output (display)

1.         get price of item

2.         get sales tax rate

3.         sales tax = price of time times sales tax rate

4          final prince = price of item plus sales tax

5.         display final price

6.         halt

 

Variables: price of item, sales tax rate, sales tax, final price

Note that the operations are numbered and each operation is unambiguous and effectively computable. We also extract and list all variables used in our pseudo-code. This will be useful when translating pseudo-code into a programming language


Example #2 - Computing Weekly Wages: Gross pay depends on the pay rate and the number of hours worked per week. However, if you work more than 40 hours, you get paid time-and-a-half for all hours worked over 40. Pseudo-code the task of computing gross pay given pay rate and hours worked.

1.         get hours worked

2.         get pay rate

3.         if hours worked ≤ 40 then

3.1       gross pay = pay rate times hours worked

4.         else

            4.1       gross pay = pay rate times 40 plus 1.5 times pay rate times (hours worked minus 40)

5.         display gross pay

6.         halt

 

            variables:  hours worked, ray rate, gross pay

This example introduces the conditional control structure. On the basis of the true/false question asked in line 3, we execute line 3.1 if the answer is True; otherwise if the answer is False we execute the lines subordinate to line 4 (i.e. line 4.1). In both cases we resume the pseudo-code at line 5.


Example #3 - Computing a Quiz Average:  Pseudo-code a routine to calculate your quiz average.

1.         get number of quizzes

2.         sum = 0

3.         count = 0

4.         while count < number of quizzes

            4.1       get quiz grade

            4.2       sum = sum + quiz grade

            4.3       count = count + 1

5.         average = sum / number of quizzes

6.         display average

7.         halt

 

            variables: number of quizzes, sum ,count, quiz grade, average

This example introduces an iterative control statement. As long as the condition in line 4 is True, we execute the subordinate  operations 4.1 - 4.3. When the condition becomes False, we resume the pseudo-code at line 5.

This is an example of a top-test or while do iterative control structure. There is also a bottom-test or repeat until iterative control structure which executes a block of statements until the condition tested at the end of the block is False.


Pseudo-code is one important step in the process of writing a program.


Pseudo-code Language Constructions : A Summary

Computation/Assignment 

        set the value of "variable" to :"arithmetic expression" or
        "variable" equals "expression" or
        "variable" = "expression"

Input/Output

        get "variable", "variable", ...
        display "variable", "variable", ...

Conditional (dot notation used for numbering subordinate statements)

        6.    if  "condition"
                    6.1    (subordinate) statement 1 
                    6.2     etc ...
        7.    else
                    7.1    (subordinate) statement 2
                    7.2    etc ...

Iterative (dot notation used for numbering subordinate statements)

        9.    while "condition" 
                    9.1    (subordinate) statement 1
                    9.2    etc ...



Return to Comp 150 Home Page

 

출처 : http://userpages.wittenberg.edu/bshelburne/Comp150/Algorithms.htm

?

공부 게시판

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

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 928102
2473 웹서버,WAS http를 https로 리다이렉트하는 여러가지 방법 new JaeSoo 2025.09.10 0
2472 웹서버,WAS SSL인증서 없이 HTTPS에서 HTTP로 되돌리기 new JaeSoo 2025.09.10 2
2471 웹서버,WAS [SSL] win-acme, Let's encrypt로 무료 SSL 인증서 발급 new JaeSoo 2025.09.10 0
2470 웹서버,WAS [SSL] Windows 10에서 Let's Encrypt로 SSL 인증서 무료 발급받기 new JaeSoo 2025.09.10 0
2469 웹서버,WAS 무료로 https SSL/TLS 인증서를 발급받을 수 있는 인증 기관 new JaeSoo 2025.09.10 0
2468 웹서버,WAS 아파치 서버에 https SSL 인증서 적용하는 방법 (apache httpd) new JaeSoo 2025.09.10 0
2467 웹서버,WAS 아파치2(Apache2) SSL HTTPS 적용하기 new JaeSoo 2025.09.10 0
2466 웹서버,WAS 아파치 웹서버에 멀티 도메인에 대한 80, 443 포트 설정하는 방법 newfile JaeSoo 2025.09.10 0
2465 소프트웨어 Google Photo 대신 Immich를 써보자 file JaeSoo 2025.08.07 126
2464 연애 남자 혹은 여자 진국 팁 JaeSoo 2025.07.24 116
2463 기타 MBTI검사 16가지 유형 “간단 명료”하게 정리! file JaeSoo 2025.07.01 133
2462 소프트웨어 [사진관리] PhotoPrism vs LibrePhoto 비교 소감 JaeSoo 2025.05.19 14
2461 네트워크 MDF실, TPS실, EPS실 이게 뭘까? file JaeSoo 2025.04.15 33
2460 업무 알아두면 좋은 직장인 용어 정리 file JaeSoo 2025.04.15 37
2459 건강 감기·독감·코로나19의 차이점, 신촌연세병원과 함께 알아봅시다. file JaeSoo 2025.01.08 29
2458 생활 집주인이 전세 보증금을 돌려주지 않을 때 JaeSoo 2024.11.29 26
2457 자동차 자전거 타이어 종류 및 추천 2편 (승차감 타이어, 국토종주!) JaeSoo 2024.10.15 53
2456 자동차 오도바이 센타 사장들은 어떤 브랜드를 싫어하고 좋아할까? [출처] 오도바이 센타 사장들은 어떤 브랜드를 싫어하고 좋아할까?|작성자 바이크신 file JaeSoo 2024.10.15 78
2455 윈도우즈 윈도우 자동 로그온 설정이 보이지 않을 때 조치사항 JaeSoo 2024.08.16 203
2454 모바일 갤럭시S22 시리즈에서 SKT LTE 무제한 핫스팟 쓰는 방법! (SKT LTE 요금제만 해당!) JaeSoo 2024.08.12 234
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 124 Next
/ 124


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너