-
Notifications
You must be signed in to change notification settings - Fork 215
/
Copy pathMedium_089_Gray_Code_Test.swift
80 lines (78 loc) · 2.73 KB
/
Medium_089_Gray_Code_Test.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
//
// Medium_089_Gray_Code_Test.swift
// Solutions
//
// Created by Di Wu on 10/21/15.
// Copyright © 2015 diwu. All rights reserved.
//
import XCTest
class Medium_089_Gray_Code_Test: XCTestCase, SolutionsTestCase {
func test_001() {
let input: Int = 1
asyncHelper(input: input)
}
func test_002() {
let input: Int = 2
asyncHelper(input: input)
}
func test_003() {
let input: Int = 3
asyncHelper(input: input)
}
func test_004() {
let input: Int = 4
asyncHelper(input: input)
}
func twoNumberSatisfyGrayCodeRule(a: Int, b: Int, N: Int) -> Bool {
var counter: Int = 0
for i in 0 ..< N {
let tmp: Int = 1 << i
let x: Int = a & tmp
let y: Int = b & tmp
if x != y {
counter += 1
}
}
if counter == 1 {
return true
} else {
return false
}
}
private func asyncHelper(input: Int) {
weak var expectation: XCTestExpectation? = self.expectation(description:timeOutName())
serialQueue().async(execute: { () -> Void in
let result: [Int] = Medium_089_Gray_Code.grayCode(input)
if input == 0 {
if result.count != 0 {
assertHelper(false, problemName:self.problemName(), input: input, resultValue: result, expectedValue: [])
}
} else {
if result.count != Int(pow(Double(2), Double(input))) {
assertHelper(false, problemName:self.problemName(), input: input, resultValue: result, expectedValue: [])
}
var prev: Int = result.last!
for i in 0 ..< result.count {
var next: Int = 0
if i == result.count - 1 {
next = result.first!
} else {
next = result[i+1]
}
if self.twoNumberSatisfyGrayCodeRule(a: result[i], b: prev, N: input) == false || self.twoNumberSatisfyGrayCodeRule(a: result[i], b: next, N: input) == false {
assertHelper(false, problemName:self.problemName(), input: input, resultValue: result, expectedValue: [])
}
prev = result[i]
}
}
if let unwrapped = expectation {
unwrapped.fulfill()
}
})
waitForExpectations(timeout:timeOut()) { (error: Error?) -> Void in
if error != nil {
assertHelper(false, problemName:self.problemName(), input: input, resultValue:self.timeOutName(), expectedValue: [])
}
}
}
}