今天的编程题目有点意思:
在游戏里面应该是很平常的,比如人物或者一个怪兽的移动,就需要计算坐标的变化。
开发一个坐标计算工具, A表示向左移动,D表示向右移动,W表示向上移动,S表示向下移动。从(0,0)点开始移动,从输入字符串里面读取一些坐标,并将最终输入结果输出到输出文件里面。
输入:
合法坐标为A(或者D或者W或者S) + 数字(两位以内)
坐标之间以;分隔。
非法坐标点需要进行丢弃。如AA10; A1A; $%$; YAD; 等。
while True:
try:
a=raw_input().strip().split(";")
point=[0,0]
for i in a:
if len(i)<2 or len(i)>3 or not i[1:].isdigit():
continue
if i[0]=="A":
point[0]-=int(i[1:])
if i[0]=='D':
point[0]+=int(i[1:])
if i[0]=='W':
point[1]+=int(i[1:])
if i[0]=='S':
point[1]-=int(i[1:])
print str(point[0])+","+str(point[1])
except:
break
这个代码还是比较简洁的,通过条件判断,实现坐标的变化