-
Notifications
You must be signed in to change notification settings - Fork 0
/
d20.3.csx
132 lines (121 loc) · 3.65 KB
/
d20.3.csx
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
using System.IO;
using System.Linq;
List<string> stdInput = new();
string s;
while ((s = Console.ReadLine()) != null)
{
stdInput.Add(s);
}
var data = stdInput.AsEnumerable().Select(a=>a.Select(b=>(b=='#')?true:false).ToArray()).ToArray();
var monster = File.ReadAllLines("d20.monster.txt").AsEnumerable().Select(a=>a.Select(b=>(b=='#')?true:false).ToArray()).ToArray();
var FullSize = data.Length;
List<(int, int)> monsterPath = new();
for(int y=0;y<monster.Length;y++){
for(int x=0;x<monster[0].Length;x++){
if(monster[y][x]){
monsterPath.Add((x,y));
//Console.WriteLine($"x: {x}, y: {y}");
}
}
}
var current = data;
bool done = false;
int tryIndex = 0;
while(!done && tryIndex < 4){
done = CompareArray(current);
if(done){
EndTask(current);
break;
}
current = Flip(current, tryIndex%2==0);
done = CompareArray(current);
if(done){
EndTask(current);
break;
}
current = Rotate(current);
tryIndex++;
}
void EndTask(bool[][] result){
var done = result.Select(a=>a.Select(b=>b?'#':'.').ToArray()).ToArray();
PaintArray(done, result);
Console.WriteLine(done.SelectMany(c=>c).Count(c=>c=='#'));
/*
foreach(var txt in done){
Console.WriteLine(String.Concat(txt));
}*/
}
bool CompareArray(bool[][] currentData){
bool found = false;
for(int y = 0;y < FullSize-monster.Length+1; y++){
for(int x=0;x < FullSize-monster[0].Length+1; x++){
if(Compare(currentData, x,y)){
found = true;
}
}
}
return found;
}
bool PaintArray(char[][] currentData, bool[][] compareData){
bool found = false;
for(int y = 0;y < FullSize-monster.Length+1; y++){
for(int x=0;x < FullSize-monster[0].Length+1; x++){
if(Compare(compareData, x,y)){
Paint(currentData,x,y);
}
}
}
return found;
}
bool Compare(bool[][] currentData, int x, int y){
foreach((int xOff, int yOff) in monsterPath){
if(!currentData[y+yOff][x+xOff]) return false;
}
return true;
}
void Paint(char[][] dataChar, int x, int y){
foreach((int xOff, int yOff) in monsterPath){
dataChar[y+yOff][x+xOff] = 'O';
}
}
/*
foreach(var txt in dataChar){
Console.WriteLine(String.Concat(txt));
}*/
//I don't know how.
//https://www.geeksforgeeks.org/rotate-a-matrix-by-90-degree-in-clockwise-direction-without-using-any-extra-space/
bool[][] Rotate(bool[][] pieceRaw){
//https://stackoverflow.com/questions/15725840/copy-one-2d-array-to-another-2d-array
bool[][] piece = pieceRaw.Select(item=>item.ToArray()).ToArray();
for (int i = 0; i < FullSize/2; i++)
{
for (int j = i; j < FullSize - 1 - i ; j++){
bool temp = piece[i][j];
piece[i][j] = piece[FullSize -1 - j][i];
piece[FullSize -1 - j][i] = piece[FullSize -1 - i][FullSize -1 - j];
piece[FullSize -1 - i][FullSize -1 - j] = piece[j][FullSize -1 - i];
piece[j][FullSize -1 - i] = temp;
}
}
return piece;
}
bool[][] Flip(bool[][] input, bool horizontal){
if(horizontal){
for(int x=0;x<FullSize;x++){
input[x] = input[x].Reverse().ToArray();
}
return input;
}
else{
for(int x=0;x<FullSize/2;x++){
Swap(ref input[x], ref input[FullSize-1-x]);
}
return input;
}
}
void Swap<T>(ref T a, ref T b)
{
var temp= a;
a = b;
b = temp;
}