-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path012.asm
More file actions
56 lines (43 loc) · 1.26 KB
/
012.asm
File metadata and controls
56 lines (43 loc) · 1.26 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
;Project Euler Problem #12
;https://projecteuler.net/problem=12
extern printf
section .data
fmt db "%ld",10,0
tnv dq 1 ;nth triangle number value
tmp2 dq 0
section .text
global main
main:
mov r8, 1 ;n
mov r11, 1
mov r12, 2
loop:
fild qword [tnv]
fsqrt
fistp qword [tmp2]
mov rcx, [tmp2] ;square root of current triangle number value
xor r9,r9 ;set r9 to 0 to count divisors
count:
xor rdx, rdx
mov rax, [tnv]
div rcx ;divide triangle number by number from sqrt(value) down to 0
xor rbx, rbx
cmp rdx, 0 ;check for remainder
cmovz rbx, r12 ;set rbx to 2 (2 factors per divisor) unless:
cmp rdx, rcx ;exact square root only add 1 divisor
cmovz rbx, r11
add r9, rbx
dec rcx
jnz count ;loop finished
cmp r9, 500 ;over 500 divisors?
jnc exit
inc r8 ;if not, check next triangle number
add [tnv], r8
jmp loop
exit:
mov rdi, fmt
mov rsi, [tnv]
mov rax, 0
call printf
xor rax, rax
ret