i trying create chess board 8 queen problem. challenge let user enter queens' positions , tell them if position wouldn't allowed due other queens. have board far
this code have far:
boardsize = input('board size: ') rows = [[0] * int(boardsize)] rows = str(rows).replace('[','').replace(']','').replace(',','') in range(int(boardsize)): print(i + 1, rows)
this produces:
board size: 8
1 0 0 0 0 0 0 0 0
2 0 0 0 0 0 0 0 0
3 0 0 0 0 0 0 0 0
4 0 0 0 0 0 0 0 0
5 0 0 0 0 0 0 0 0
6 0 0 0 0 0 0 0 0
7 0 0 0 0 0 0 0 0
8 0 0 0 0 0 0 0 0
i can't see way enter "q" (to symbolise queen) want enter it. reprint board q instead of 1 of zeros , repeat until 8 queens placed or there no space queen. must user controlled.
i recommend instead of storing whole grid, store queen position in each row. because 1 queen can exist in each row, know enough store queen. makes life bit easier have direct pointers queens (rather having iterate through board find queens). use this:
sample_positions = [0, 2, 4, 1, 3, 5, none, none] def print_positions(positions): ind, pos in enumerate(positions): row = ["_"] * len(positions) if pos not none: row[pos] = "q" print("{}: {}".format(ind, " ".join(row))) x, y = map(int, input("enter new queen position> ").split()) sample_positions[y] = x print_positions(sample_positions)
this program runs this:
enter new queen position> 6 7 0: q _ _ _ _ _ _ _ 1: _ _ q _ _ _ _ _ 2: _ _ _ _ q _ _ _ 3: _ q _ _ _ _ _ _ 4: _ _ _ q _ _ _ _ 5: _ _ _ _ _ q _ _ 6: _ _ _ _ _ _ _ _ 7: _ _ _ _ _ _ q _
i've included example of how might take input (although want write validation function , apply first. i've replaced printing functionality little more pythonic - generally, doing string operations on repr of list isn't idea. also, example input assumes both x
, y
given integers - can change letters or whatever appropriate. i've moved whole thing little more 0-based simplicity of implementation - i'd recommend using underscore empty cell, not integer.
presumably you're not too interested in performance. program build empty row each row goes through - funky generator chaining make couple of nanoseconds faster, make answer more complicated is.
this modified excerpt queens project. (disclaimer: wrote it). should wish refer more on how representation works or how might validate board in model, feel free. note project different yours- mine brute-forces possible solutions , features no interactive input.
Comments
Post a Comment