day 9, the hardest so far, spent to much time debugging
This commit is contained in:
parent
e51de70c36
commit
e4d64206de
|
@ -0,0 +1,20 @@
|
|||
BEGIN{P["0_0"]=1; Hx=Hy=Tx=Ty=0}
|
||||
function abs(x) { return x>0?x:-x}
|
||||
{
|
||||
print "==", Hx","Hy, ";", Tx","Ty, "==", $1, $2
|
||||
for(i=1;i<=$2;i++){
|
||||
if($1=="R") {Hx++}
|
||||
if($1=="L") {Hx--}
|
||||
if($1=="U") {Hy++}
|
||||
if($1=="D") {Hy--}
|
||||
dh = abs(Hx-Tx) # tension horizontale
|
||||
dv = abs(Hy-Ty) # tension vertivale
|
||||
if(dh>1 && $1=="R") {Tx++; if (dv>0) {Ty=Hy}}
|
||||
if(dh>1 && $1=="L") {Tx--; if (dv>0) {Ty=Hy}}
|
||||
if(dv>1 && $1=="U") {Ty++; if (dh>0) {Tx=Hx}}
|
||||
if(dv>1 && $1=="D") {Ty--; if (dh>0) {Tx=Hx}}
|
||||
P[Ty "_" Tx]=1
|
||||
print Hx, Hy, ";", "dh:"dh, "dv:"dv, "=>", Tx, Ty
|
||||
}
|
||||
}
|
||||
END{print length(P)}
|
|
@ -0,0 +1,30 @@
|
|||
import sys
|
||||
|
||||
rope = [(0,0) for _ in range(10)]
|
||||
P = [{(0,0)} for _ in range(10) ]
|
||||
D = {"R":(1,0),"L":(-1,0),"U":(0,1),"D":(0,-1)}
|
||||
|
||||
for l in sys.stdin.read().splitlines():
|
||||
M, q = l.split(" ")
|
||||
q = int(q)
|
||||
for k in range(q):
|
||||
(x,y) = rope[0]
|
||||
(dx,dy) = D[M]
|
||||
rope[0] = (x+dx, y+dy)
|
||||
for i in range(1,10):
|
||||
(Hx,Hy) = rope[i-1]
|
||||
(Tx,Ty) = rope[i]
|
||||
dh = Hx-Tx # tension horizontale
|
||||
dv = Hy-Ty # tension vertivale
|
||||
if (abs(dh)>1):
|
||||
Tx += 1 if dh > 0 else -1
|
||||
if (abs(dv)>0):
|
||||
Ty += 1 if dv > 0 else -1
|
||||
elif (abs(dv)>1):
|
||||
Ty += 1 if dv > 0 else -1
|
||||
if (abs(dh)>0):
|
||||
Tx += 1 if dh > 0 else -1
|
||||
P[i].add((Tx,Ty))
|
||||
rope[i] = (Tx,Ty)
|
||||
|
||||
print(*(len(p) for p in P))
|
Loading…
Reference in New Issue