1. Trang chủ
  2. » Kỹ Thuật - Công Nghệ

Lecture Computer organization and assembly language - Lecture 26: Recursion and String Operations - TRƯỜNG CÁN BỘ QUẢN LÝ GIÁO DỤC THÀNH PHỐ HỒ CHÍ MINH

10 7 0

Đang tải... (xem toàn văn)

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 10
Dung lượng 87,68 KB

Nội dung

– Explicit Access to Stack Parameters – Passing Arguments by Reference. ( cont.[r]

(1)

CSC 221

Computer Organization and Assembly Language

Lecture 26:

(2)

Lecture 25: Review

Assembly Implementation of:

• Stack Parameters

– INVOKE Directive – PROC Directive – PROTO Directive

(3)

Lecture 25: Review

Assembly Implementation of:

• Stack Frames

– Explicit Access to Stack Parameters – Passing Arguments by Reference

(4)

Lecture Outline

• Advanced Procedures: • Recursion

– What is recursion?

– Recursively Calculating a Sum – Calculating a Factorial

• String Primitive Instructions

(5)

Lecture Outline

• Selected String Procedures

(6)

Recursion

• What is recursion?

• Recursively Calculating a Sum

(7)

What is Recursion?

• The process created when

– A procedure calls itself

– Procedure A calls procedure B, which in turn calls procedure A

• Using a graph in which each node is a procedure and

each edge is a procedure call, recursion forms a cycle:

A

B

D E

(8)

Recursively Calculating a Sum

CalcSum PROC

cmp ecx,0 ; check counter value

jz L2 ; quit if zero

add eax,ecx ; otherwise, add to

sum

dec ecx ; decrement counter

call CalcSum ; recursive call

L2: ret

CalcSum ENDP

The CalcSum procedure recursively calculates the sum of an array of integers Receives: ECX = count Returns: EAX = sum

(9)

Recursively Calculating a Sum .code

main PROC

mov ecx,10 ; count = 10 mov eax,0 ; holds the sum call CalcSum ; calculate sum

L1: invoke dwtoa, eax, addr disp1 ; display eax invoke StdOut, addr disp1

invoke ExitProcess,0 main ENDP

; -CalcSum PROC

; Calculates the sum of a list of integers ; Receives: ECX = count | Returns: EAX = sum

; -cmp ecx,0 ; check counter value jz L2 ; quit if zero

add eax,ecx ; otherwise, add to sum dec ecx ; decrement counter

call CalcSum ; recursive call L2: ret

(10)

Calculating a Factorial (1 of 3)

int function factorial(int n) {

if(n == 0) return 1; else

return n * factorial(n-1); }

5! = * 4!

4! = * 3!

3! = * 2!

2! = * 1!

1! = * 0!

0! =

(base case)

1 * = * = * = * = 24 * 24 = 120

1 = recursive calls backing up

This function calculates the

factorial of integer n A new value of n is saved in each stack frame:

Ngày đăng: 01/04/2021, 02:51

w