mirror of
https://git.plasmaofthedawn.com/adventofcode.git
synced 2025-12-23 10:07:35 -06:00
day5 done
This commit is contained in:
162
src/plasl/2025/day5/part1.psl
Normal file
162
src/plasl/2025/day5/part1.psl
Normal file
@@ -0,0 +1,162 @@
|
||||
|
||||
i64 write(i32, ptr i8, u64) {
|
||||
`scsbsa`
|
||||
syscall3(i64(1), `la` as i64, `lb` as i64, `lc` as i64)
|
||||
}
|
||||
|
||||
i64 read(i32, ptr i8, u64) {
|
||||
`scsbsa`
|
||||
syscall3(i64(0), `la` as i64, `lb` as i64, `lc` as i64)
|
||||
}
|
||||
|
||||
i32 open(ptr i8, i32, i32) {
|
||||
`scsbsa`
|
||||
syscall3(i64(2), `la` as i64, `lb` as i64, `lc` as i64)
|
||||
as i32
|
||||
}
|
||||
|
||||
void exit(i32) {
|
||||
as i64 i64(231) rev
|
||||
syscall1 trash
|
||||
}
|
||||
|
||||
void putc(i8) {
|
||||
array i8[1] `dstr` store
|
||||
write(1, `lt`, u64(1)) trash
|
||||
}
|
||||
|
||||
u64 strlen(ptr i8) {
|
||||
dup while(dup load i8(0) !=) { 1+ } `r-`
|
||||
}
|
||||
|
||||
void print(ptr i8) {
|
||||
1 rev dup strlen write trash
|
||||
}
|
||||
|
||||
void println(ptr i8) {
|
||||
print i8(10) putc
|
||||
}
|
||||
|
||||
void printnum(i32) {
|
||||
|
||||
if (dup 0 ==) {
|
||||
putc('0')
|
||||
} else if (dup 0 <) {
|
||||
`0r-` '-' putc
|
||||
}
|
||||
|
||||
array i8[11] 10+ dup i8(0) store -1+ `sb`
|
||||
|
||||
while (dup 0 !=) {
|
||||
10 divmod 48+ as i8
|
||||
`lb` rev store
|
||||
`lb` -1+ `sb`
|
||||
} trash
|
||||
print(`lb`1+)
|
||||
|
||||
}
|
||||
|
||||
void printnum64(u64) {
|
||||
|
||||
if (dup u64(0) ==) {
|
||||
putc('0')
|
||||
}
|
||||
|
||||
array i8[22] 22+ dup i8(0) store -1+ `sb`
|
||||
|
||||
while (dup u64(0) !=) {
|
||||
u64(10) divmod u64(48)+ as i8
|
||||
`lb` rev store
|
||||
`lb` -1+ `sb`
|
||||
} trash
|
||||
|
||||
print(`lb`1+)
|
||||
|
||||
}
|
||||
|
||||
i32 atoi(ptr i8) {
|
||||
set string
|
||||
0
|
||||
while (get string load '0' >= get string load '9' <= &) {
|
||||
10* get string load '0'- as i32 +
|
||||
get string 1+ set string
|
||||
}
|
||||
}
|
||||
|
||||
u64 atol(ptr i8) {
|
||||
set string
|
||||
u64(0)
|
||||
while (get string load '0' >= get string load '9' <= &) {
|
||||
u64(10)* get string load '0'- as u64 +
|
||||
get string 1+ set string
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
i32 abs(i32) {
|
||||
if (dup 0 <) {`0r-`}
|
||||
}
|
||||
|
||||
void _start() {
|
||||
|
||||
array i8[65535] set buffer
|
||||
get buffer i8(48) store
|
||||
read(0, get buffer, u64(65535)) as i32 set size
|
||||
#get buffer get size+ i8(10) store
|
||||
|
||||
array u64[256] set lower
|
||||
array u64[256] set higher
|
||||
0 set bounds
|
||||
|
||||
u64(0) `so`
|
||||
`0si`
|
||||
|
||||
while (buffer[`li`] load i8(10) != buffer[`li1+`] load i8(10) != &) {
|
||||
while (buffer[`li`] load i8(10) !=) {
|
||||
|
||||
lower[get bounds] atol(buffer[`li`]) dup printnum64 store
|
||||
while (buffer[`li`] load '-' !=) { inc(i) }
|
||||
inc(i) ',' putc
|
||||
higher[get bounds] atol(buffer[`li`]) dup printnum64 store
|
||||
while (buffer[`li`] load i8(10) !=) { inc(i) }
|
||||
|
||||
inc(bounds)
|
||||
|
||||
inc(i) i8(10) putc
|
||||
|
||||
}
|
||||
}
|
||||
inc(i)
|
||||
i8(10) putc
|
||||
|
||||
while (get i get size 1- < ) {
|
||||
atol(buffer[`li`]) dup printnum64 `sc`
|
||||
inc(i)
|
||||
|
||||
`0sj`
|
||||
while (`lj` get bounds <) {
|
||||
|
||||
if (higher[`lj`] load `lc` >= lower[`lj`] load `lc` <= &) {
|
||||
inc(o)
|
||||
'y' putc
|
||||
# poor man's break
|
||||
`lj65535+sj`
|
||||
}
|
||||
|
||||
inc(j)
|
||||
}
|
||||
|
||||
i8(10) putc
|
||||
|
||||
while (buffer[`li`] load i8(10) !=) { inc(i) }
|
||||
inc(i)
|
||||
}
|
||||
|
||||
println("answer:")
|
||||
`lo` printnum64 i8(10) putc
|
||||
exit(0)
|
||||
}
|
||||
|
||||
void main() {
|
||||
_start
|
||||
}
|
||||
226
src/plasl/2025/day5/part2.psl
Normal file
226
src/plasl/2025/day5/part2.psl
Normal file
@@ -0,0 +1,226 @@
|
||||
|
||||
i64 write(i32, ptr i8, u64) {
|
||||
`scsbsa`
|
||||
syscall3(i64(1), `la` as i64, `lb` as i64, `lc` as i64)
|
||||
}
|
||||
|
||||
i64 read(i32, ptr i8, u64) {
|
||||
`scsbsa`
|
||||
syscall3(i64(0), `la` as i64, `lb` as i64, `lc` as i64)
|
||||
}
|
||||
|
||||
i32 open(ptr i8, i32, i32) {
|
||||
`scsbsa`
|
||||
syscall3(i64(2), `la` as i64, `lb` as i64, `lc` as i64)
|
||||
as i32
|
||||
}
|
||||
|
||||
void exit(i32) {
|
||||
as i64 i64(231) rev
|
||||
syscall1 trash
|
||||
}
|
||||
|
||||
void putc(i8) {
|
||||
array i8[1] `dstr` store
|
||||
write(1, `lt`, u64(1)) trash
|
||||
}
|
||||
|
||||
u64 strlen(ptr i8) {
|
||||
dup while(dup load i8(0) !=) { 1+ } `r-`
|
||||
}
|
||||
|
||||
void print(ptr i8) {
|
||||
1 rev dup strlen write trash
|
||||
}
|
||||
|
||||
void println(ptr i8) {
|
||||
print i8(10) putc
|
||||
}
|
||||
|
||||
void printnum(i32) {
|
||||
|
||||
if (dup 0 ==) {
|
||||
putc('0')
|
||||
} else if (dup 0 <) {
|
||||
`0r-` '-' putc
|
||||
}
|
||||
|
||||
array i8[11] 10+ dup i8(0) store -1+ `sb`
|
||||
|
||||
while (dup 0 !=) {
|
||||
10 divmod 48+ as i8
|
||||
`lb` rev store
|
||||
`lb` -1+ `sb`
|
||||
} trash
|
||||
print(`lb`1+)
|
||||
|
||||
}
|
||||
|
||||
void printnum64(u64) {
|
||||
|
||||
if (dup u64(0) ==) {
|
||||
putc('0')
|
||||
}
|
||||
|
||||
array i8[22] 22+ dup i8(0) store -1+ `sb`
|
||||
|
||||
while (dup u64(0) !=) {
|
||||
u64(10) divmod u64(48)+ as i8
|
||||
`lb` rev store
|
||||
`lb` -1+ `sb`
|
||||
} trash
|
||||
|
||||
print(`lb`1+)
|
||||
|
||||
}
|
||||
|
||||
i32 atoi(ptr i8) {
|
||||
set string
|
||||
0
|
||||
while (get string load '0' >= get string load '9' <= &) {
|
||||
10* get string load '0'- as i32 +
|
||||
get string 1+ set string
|
||||
}
|
||||
}
|
||||
|
||||
u64 atol(ptr i8) {
|
||||
set string
|
||||
u64(0)
|
||||
while (get string load '0' >= get string load '9' <= &) {
|
||||
u64(10)* get string load '0'- as u64 +
|
||||
get string 1+ set string
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
i32 abs(i32) {
|
||||
if (dup 0 <) {`0r-`}
|
||||
}
|
||||
|
||||
void _start() {
|
||||
|
||||
array i8[65535] set buffer
|
||||
get buffer i8(48) store
|
||||
read(0, get buffer, u64(65535)) as i32 set size
|
||||
#get buffer get size+ i8(10) store
|
||||
|
||||
array u64[256] set lower
|
||||
array u64[256] set higher
|
||||
0 set bounds
|
||||
|
||||
u64(0) `so`
|
||||
`0si`
|
||||
|
||||
while (buffer[`li`] load i8(10) != buffer[`li1+`] load i8(10) != &) {
|
||||
while (buffer[`li`] load i8(10) !=) {
|
||||
|
||||
lower[get bounds] atol(buffer[`li`]) dup printnum64 store
|
||||
while (buffer[`li`] load '-' !=) { inc(i) }
|
||||
inc(i) ',' putc
|
||||
higher[get bounds] atol(buffer[`li`]) dup printnum64 store
|
||||
while (buffer[`li`] load i8(10) !=) { inc(i) }
|
||||
|
||||
inc(bounds)
|
||||
|
||||
inc(i) i8(10) putc
|
||||
|
||||
}
|
||||
}
|
||||
inc(i)
|
||||
i8(10) putc
|
||||
|
||||
get bounds 1- set j
|
||||
while (`lj` 0 >=) {
|
||||
|
||||
|
||||
# merge flag
|
||||
u1(0) `sm`
|
||||
|
||||
# check for merge
|
||||
`ljsk`
|
||||
|
||||
while (`lk1` >= `lm` u1(0) == &) {
|
||||
dec(k)
|
||||
#get j printnum ',' putc get k printnum i8(10) putc
|
||||
if (lower[`lk`] load lower[`lj`] load <=
|
||||
higher[`lk`] load higher[`lj`] load >= &) {
|
||||
# inner merge - do nothing
|
||||
|
||||
println("inner merge")
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
higher[`lj`] load printnum64 '.' putc lower[`lj`] load printnum64 i8(10) putc
|
||||
|
||||
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
|
||||
# flag
|
||||
u1(1) `sm`
|
||||
} else if (lower[`lk`] load lower[`lj`] load >=
|
||||
higher[`lk`] load higher[`lj`] load <= &) {
|
||||
|
||||
# outer merge, replace that range with this one
|
||||
|
||||
println("outer merge")
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
higher[`lj`] load printnum64 '.' putc lower[`lj`] load printnum64 i8(10) putc
|
||||
|
||||
higher[`lk`] higher[`lj`] load store
|
||||
lower[`lk`] lower[`lj`] load store
|
||||
|
||||
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
|
||||
# flag
|
||||
u1(1) `sm`
|
||||
} else if (lower[`lk`] load higher[`lj`] load <=
|
||||
lower[`lk`] load lower[`lj`] load >= &) {
|
||||
|
||||
# left merge, replace bottom with new bottom
|
||||
|
||||
println("left merge")
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
higher[`lj`] load printnum64 '.' putc lower[`lj`] load printnum64 i8(10) putc
|
||||
|
||||
lower[`lk`] lower[`lj`] load store
|
||||
|
||||
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
|
||||
u1(1) `sm`
|
||||
} else if (higher[`lk`] load higher[`lj`] load <=
|
||||
higher[`lk`] load lower[`lj`] load >= &) {
|
||||
|
||||
# right merge, replace top with new top
|
||||
|
||||
println("right merge")
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
higher[`lj`] load printnum64 '.' putc lower[`lj`] load printnum64 i8(10) putc
|
||||
|
||||
higher[`lk`] higher[`lj`] load store
|
||||
|
||||
higher[`lk`] load printnum64 '.' putc lower[`lk`] load printnum64 i8(10) putc
|
||||
|
||||
u1(1) `sm`
|
||||
}
|
||||
}
|
||||
|
||||
# if no merge was performed, or last one
|
||||
if (`lm` u1(0) ==) {
|
||||
lower[`lj`] load dup printnum64 '-' putc
|
||||
higher[`lj`] load dup printnum64
|
||||
|
||||
# 1+ for the inclusive bounds
|
||||
`r-`u64(1)`+lo+so`
|
||||
}
|
||||
|
||||
dec(j) i8(10) putc
|
||||
}
|
||||
|
||||
println("answer:")
|
||||
`lo` printnum64 i8(10) putc
|
||||
exit(0)
|
||||
}
|
||||
|
||||
void main() {
|
||||
_start
|
||||
}
|
||||
Reference in New Issue
Block a user