Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
d9740a28a4 | |||
419d3d7dcc | |||
6af10ba53d |
@ -3,11 +3,11 @@ name: default
|
||||
|
||||
steps:
|
||||
- name: test
|
||||
image: rust:1.38.0
|
||||
image: rust:1.38.0-alpine
|
||||
commands:
|
||||
- cargo test
|
||||
- name: build_relase
|
||||
image: rust:1.38.0
|
||||
image: rust:1.38.0-alpine
|
||||
commands:
|
||||
- cargo install --path . --root . -f
|
||||
- strip bin/tictactoe
|
||||
|
21
src/main.rs
21
src/main.rs
@ -2,8 +2,10 @@ use std::env::args;
|
||||
use std::fmt;
|
||||
use std::io;
|
||||
use std::io::Write;
|
||||
use std::iter;
|
||||
use std::ops::{Index, IndexMut};
|
||||
use std::str::FromStr;
|
||||
use std::time::SystemTime;
|
||||
|
||||
#[derive(Copy, Clone, Debug, PartialEq)]
|
||||
enum State {
|
||||
@ -92,11 +94,7 @@ impl FromStr for Board {
|
||||
|
||||
impl Board {
|
||||
fn new(size: usize) -> Board {
|
||||
let mut b = Vec::with_capacity(size * size);
|
||||
for _ in 0..b.capacity() {
|
||||
b.push(State::N);
|
||||
}
|
||||
Board(b)
|
||||
Board(iter::repeat(State::N).take(size * size).collect())
|
||||
}
|
||||
|
||||
fn dimension(&self) -> usize {
|
||||
@ -172,6 +170,17 @@ fn main() {
|
||||
let dim = board.dimension();
|
||||
(board, criteria.unwrap_or(dim))
|
||||
};
|
||||
let players_rev = State::players().iter().rev().cloned().collect::<Vec<_>>();
|
||||
|
||||
let players: &[State] = if SystemTime::now()
|
||||
.duration_since(SystemTime::UNIX_EPOCH)
|
||||
.map(|d| d.as_millis() % 2 == 0)
|
||||
.unwrap_or(false)
|
||||
{
|
||||
State::players()
|
||||
} else {
|
||||
&players_rev[..]
|
||||
};
|
||||
let stdin = std::io::stdin();
|
||||
println!("{}", &board);
|
||||
let winner = loop {
|
||||
@ -179,7 +188,7 @@ fn main() {
|
||||
break winner;
|
||||
}
|
||||
let mut input = String::new();
|
||||
for s in State::players() {
|
||||
for s in players {
|
||||
loop {
|
||||
let (x, y) = loop {
|
||||
print!("{}, your move: (x y) ", s);
|
||||
|
Loading…
x
Reference in New Issue
Block a user