Compare commits
No commits in common. "d491307031a7aa161e8c00f7fb16600fed5e0c53" and "b24790189904b0295235d2d75c411e03b9948353" have entirely different histories.
d491307031
...
b247901899
@ -1,4 +1,6 @@
|
|||||||
A X draw = 1 + 3 = 4
|
A X draw = 1 + 3 = 4. Also my parsing just takes the 1st and 3rd characters of
|
||||||
|
the lines so I can type anything else after that and it'll work as an input
|
||||||
|
file kek
|
||||||
A Y win = 2 + 6 = 8
|
A Y win = 2 + 6 = 8
|
||||||
A Z loss = 3 + 0 = 3 <- not 9
|
A Z loss = 3 + 0 = 3 <- not 9
|
||||||
B X loss = 1 + 0 = 1
|
B X loss = 1 + 0 = 1
|
||||||
|
2500
zig/2/input.txt
2500
zig/2/input.txt
File diff suppressed because it is too large
Load Diff
@ -1,19 +0,0 @@
|
|||||||
const std = @import("std");
|
|
||||||
|
|
||||||
// define wins lookup table
|
|
||||||
|
|
||||||
pub fn main() !void {
|
|
||||||
var file = try std.fs.cwd().openFile("input.txt", .{});
|
|
||||||
defer file.close();
|
|
||||||
|
|
||||||
var a = std.io.bufferedReader(file.reader());
|
|
||||||
var readerStream = a.reader();
|
|
||||||
|
|
||||||
var buf: [32]u8 = undefined;
|
|
||||||
var score: i32 = 0;
|
|
||||||
while (try readerStream.readUntilDelimiterOrEof(&buf, '\n')) |line| {
|
|
||||||
// get score
|
|
||||||
}
|
|
||||||
|
|
||||||
std.debug.print("{d}\n", .{score});
|
|
||||||
}
|
|
300
zig/3/input.txt
300
zig/3/input.txt
@ -1,300 +0,0 @@
|
|||||||
qFdBBvtHHfvRlfvsqldvqjPpQmnQmjnjjjTRTLGRNG
|
|
||||||
ZCWhhCsJCzSJzSbzgsmPTGNNPPNGjgLTLjgn
|
|
||||||
WJZsbJMwJcszJcScwhVltFwBFBlqddvFdHDfqq
|
|
||||||
crtTsGTtqFThGQGCrsjTwdNJwpRdnJJwffRClpSf
|
|
||||||
PWVBPVHLvHHVgvZWBzmPpnfRSJJRQnSRflRPSNSl
|
|
||||||
gmzBzDgzmZQWLDLLgVmDrqGhsscrqDMGhcqtqcFr
|
|
||||||
HsbcdVrsbVbcLfPqqQsqqtPj
|
|
||||||
mMBFzZRnmFMRBDnDFBGZDGdDqLjtdQtPtgfPfttgtqgq
|
|
||||||
BZvZZdJMBFdJhSvhbhchcHll
|
|
||||||
GNRSqRfcNTpfGCcqjfzBpDQPWBzgDpQsPWzW
|
|
||||||
rrSdnVHlbMdLdBDzgtBtBmQt
|
|
||||||
rbFwwnLFLFwlMLrFwFhMVLrGNSTfZTRhfTqjGJRRZTCNcf
|
|
||||||
QWTnQCnWNNWmTnSPQwmqDbcscbpcjPjVPbrjpq
|
|
||||||
vJhzZNlNNgdzgzJdlGzHHcHDpjsHqrvbVrbvrD
|
|
||||||
RzRdRlhLgtCwCWSLnN
|
|
||||||
SFTJFTTwTVVSJBnSTdvNNfWbZCZWNZCNNhBv
|
|
||||||
srLrcHDcsjtLcLLcrLctjlcvbDNhmWCvNhZWGZZhNvhZmb
|
|
||||||
rclgtMPrrSgVTgJCng
|
|
||||||
DbrhDzcDffbzNbZvZWSSqSTNSVWv
|
|
||||||
gCPltPmCPglFnPFwtGPhGPwTCTdZZWZVRvWqdRqVVdTdvR
|
|
||||||
hLBhlmlstcffBzrpfj
|
|
||||||
wFLLmhMfwZLDwmMNRhZwRLDvJgldbJHPdQvcQHHJQPgH
|
|
||||||
bjrVrTSSJdQHcVll
|
|
||||||
CGCSsCCBpspBrqbSttpbqWmWZRmfFRZhZMNNLFqFLm
|
|
||||||
zWGjjBHGjzzTWMjhtDDWtPPlJZPJpvqQrmZTqQQpmr
|
|
||||||
RFbVLcBVLRcRVcCsCCqvpCZqmplqQJmPrlvQ
|
|
||||||
FLNRRSSRgScSVLLLNdFdwjHjnftBtGMgMjzHgzjWjj
|
|
||||||
znVSqnqbqzSbzTHqDDZmlcFcnhDMnDmn
|
|
||||||
LtjsvdvLJdjfFwRRCCMlChwCpMcclCcZ
|
|
||||||
LgvjjfjFQVgNTgWq
|
|
||||||
SJRJRFFCMSsGRMMwtZJRCVTgqgTVgTBCVpjTjmmWlB
|
|
||||||
ccvnnpnDVqTcBVTV
|
|
||||||
vPHprdHdpnzHSMsSrMRZJGws
|
|
||||||
GddGrcGNHnGvnCHddvCSWqTSWsTwTWShbHlhhb
|
|
||||||
gDPzLRVZgQfpRRFQDDVFDfzhSzsTBqqqnqbhnWTSSlST
|
|
||||||
QVFfFgRQQgLtgffZRfpFPfntjrcrjCmtCdMMmjMdJJJNtm
|
|
||||||
jjmNcpGCNmDqqsBfnZnGGGRLsZ
|
|
||||||
lrmlVWlQQtWllgtbQVrWBnZsJgsRLfZLhZBBBffL
|
|
||||||
rWMVQtrFlbFlSSMHVSdHHNHdcdDcddzppzzm
|
|
||||||
bTpjpjcVTLmphbLppJwqzqwJLqqzzzgRLJ
|
|
||||||
sdHNbrvNHrqPvZZZPRww
|
|
||||||
bNQCrCNtNsSlhffhVhpVWFCW
|
|
||||||
lpNnpMMZZDbNbnBjcrbjvScFmbGj
|
|
||||||
wqhdqVqdscrjdLsv
|
|
||||||
HQftVqWCfhwqtCCjWwfqzzVPZRJQgMlggZMMMZTNMNTnNRTN
|
|
||||||
fvvGbFtVmtTwgtMT
|
|
||||||
WcCcClzPCCcczJJScPWWZzBDmwbhBBHSghgDDMTHMDBD
|
|
||||||
nWPljWzZWnbcbRsNFjFFdFdVjFsj
|
|
||||||
NQrcLNmQGRfGLHHLZgbbnpjZJJJndbgnlv
|
|
||||||
DWtThDWtzzhltWTwjbdpvjbgqjgg
|
|
||||||
VtSPFWtBPBFSFBWCStshWBmlRfHfMRcfQLQLLlmCrCcN
|
|
||||||
pbmwqJnqSJVwwDPCjZZzrZfD
|
|
||||||
QtssBTvNdNvNtQvQGpGhdjPjDjczZDfjhgPPDcgjgr
|
|
||||||
GltptQpMGNNpRWlWFVFHJFHLWH
|
|
||||||
ZLLsDGGVhZcQQLhrLshrVFwHnWqJnWMnJJJnqfWfGn
|
|
||||||
jMlPdTlPlgCgFpngFWFnJfpw
|
|
||||||
TlTNbdSSTSTmTjPMTCdBPjBMrLDczsZcNrDhRNDRQRLLRVVz
|
|
||||||
HDLpBqDVVTvwGDDNRT
|
|
||||||
PlVWjfhsPMMmWtlFNTrhrrvCCCTNNbvw
|
|
||||||
lsglfgVJmsfMjJfSqSzdZnLgqcnLnp
|
|
||||||
pfCDJWBpfDffpJLgQJzzVzNrgNgNgNhNzmVr
|
|
||||||
ZnnGZbGTPZnsnRFdTlbrwdrNzrrmmWwmwVwttH
|
|
||||||
GbPGRvTnZljWnpqSMMCjqJQSCf
|
|
||||||
ZgnFgwggznFrfrwfHhNMMr
|
|
||||||
pctLCLRhPHBLMLWfBL
|
|
||||||
JJcdJcQCCJmQJppmlgndnFslsVnsvghZ
|
|
||||||
WpMgTppWGSWWJmJDpJcJJhqm
|
|
||||||
zZzjZNHvNjPvNsbZLbRLzsPcqhVJSVttdwhwmdRhtdJRVd
|
|
||||||
sLbvvCZCPSSSbbPfNlQQTQGBllCTnMnWQn
|
|
||||||
fwbwswddwSbBfDBggMBPDPhHcPWDmhHhmWnWPC
|
|
||||||
FQFlzLCzQTlrTTzvltFqFrmhPHjnhhnnchcJWcRRmRRq
|
|
||||||
lpLzlFZzCltrTNlTztQLZfSMGBNdSBVwbBNVSMSbVs
|
|
||||||
FMmgbTFdgLSgFQdjrRPrQBPDdj
|
|
||||||
ZqqWRvsfGrrPvvPC
|
|
||||||
wZzwnqccRwRNNpRSMztSMMFbgzLTFS
|
|
||||||
qTwBPfTfqQDMDrssHdvtRHccHMjR
|
|
||||||
gWSZGWzGFhnFFgnhNsRHtRdsVjZcRjHs
|
|
||||||
jgplhpJJFgnDrrwfqprwDP
|
|
||||||
CWhMSRfWhVVnRSZnVVdsLQqQMzGqLBvGMQqczv
|
|
||||||
PHbpNwrjJplttvcclLlQzzDszc
|
|
||||||
NrJbJrFNNJNPrmwrtbjtNmCfSWfWhSZZfSWCsfShfFVR
|
|
||||||
VLhRPLGLRPRSStRRLwfGqfmDwbmqbqqDlD
|
|
||||||
rBSFvppnzTbwDwlDcFWm
|
|
||||||
MJrnJTMvMsrTsPtshRNPZdSLhL
|
|
||||||
BZBrRCrnCQBBnZfGqhGGMMRcthMhMG
|
|
||||||
TLjsCdDCPTvNssjdsPsDgsgqGcPHczchtHczWzPWzzlWhG
|
|
||||||
gsTpsdNbvNNjNSpsNDTsmCnSVQFmSFwZnQBnmnQQ
|
|
||||||
llbsNsWrmbrGbWCNtBjcCFBzQFZBCFjF
|
|
||||||
LdSpwgdqSgzwJdRdLMRHLjQQjHjFHctjHBDTZj
|
|
||||||
gSppgpSJMhpzwrhblfbhhlWlnW
|
|
||||||
DwhTvvsJZWsBnDzPpBLbFp
|
|
||||||
GHtNGRGNdzbMBBtmBt
|
|
||||||
NljlCSVSHdjGSQRGlCQSCswqfWzhZfTcfzcJvshJ
|
|
||||||
lmsGNFsDGqCbFQBbffjjwpzptw
|
|
||||||
hRQdvdrvrvSngWnvnHrTMfzfzRtftzwVTwwpzB
|
|
||||||
HnSSWrvLJvWJGFDsmFLPDFcQ
|
|
||||||
bwwpGphpLghpTvpWphvJlFLJqqltjSjVlSStSR
|
|
||||||
cmszZdDdBZzcNcDCDcNsmNMcqVjMJStFRJltVPVrlVPjVJll
|
|
||||||
HcdmcCzzzQcHNcsCdpnGnhwGgnRggHvbbR
|
|
||||||
CfMBbwBGbMbDCFrDvhFFDT
|
|
||||||
mjzRjjRdSmjPnzFZgnnrTT
|
|
||||||
cmSsVcHjLHTwMfLBpBpBwM
|
|
||||||
whqqfZzgHvhSzzVNVDbpDbmbVbNpJD
|
|
||||||
GcQFntGTCCcCTMCTGBlJsJsDDWpRbWBsJpNS
|
|
||||||
FnPcrGFFdddMnCnTqgqgqPHfLjLqgSzz
|
|
||||||
zMSzzjssFdGnszRtNftqqwFHbbZw
|
|
||||||
RRPLVrgrwHqBqgwt
|
|
||||||
rPWmLCTCQlCQQmmrWLrQShJshhzdhhJjcSjlzRds
|
|
||||||
lvgvCDfPqLHppqpCCDJncbntttbBtBBVHjwtrB
|
|
||||||
TdddszSQsWcngjzVbcVZ
|
|
||||||
hRWsTRTGQhNRGhRTFSWmlpgfqlvLmplPqvvGgv
|
|
||||||
LbWFLQdWWPwWSjSHPHRfppHHDRpggR
|
|
||||||
zmqqNNzlzmnzzNCmVCmtBzpfGsfpBgDgspprcfcfsrRB
|
|
||||||
qNNVNJtNmmmNzznVJzvCTDZWhvZZjZFbWQQhFhbZSw
|
|
||||||
DjdHqJVVhHVZjhDHPWtDtZLFBRBFmSRTFSbwmRRTffTTJf
|
|
||||||
NNznnGlgMQsnQzNclzpfSRSMRmfPMmFRwBwB
|
|
||||||
vzrcGcNcPPvHvHPt
|
|
||||||
wLCcmZwWTNtZNdMSMGSCnJGGMB
|
|
||||||
RFbHsPhVvFPRjlshhrnQnGjQGSdSqJfqnQBM
|
|
||||||
HhzVlFHhPwzScmSTgL
|
|
||||||
TNlBhDNvNBFpJgpPPpDQ
|
|
||||||
jjfCdCZZqsCZsbdqPgFGGMRzSFMqQMRS
|
|
||||||
jnWPtWssCtWcmZbbtstvnrrvhVBhTNNhBHlBlL
|
|
||||||
DZwNWPDzPVWbJngrQjrNnrQcMg
|
|
||||||
GRRfttLBhhvTvmLmFcFcgFFSnjWrnsrG
|
|
||||||
TLthBWtTRLHqhlLLfmhBqVPDJVdPwzJCPPZHwdDdVd
|
|
||||||
GGVhrVSMQwQqfVssVvnWFgvgWn
|
|
||||||
jtlcRBBtQRmpWsjzFCvzWnvF
|
|
||||||
QPcRbpppDmNDtPPblZMfhZdDwdMrqSSGrq
|
|
||||||
ZRrdtBdQvQsWnnfWFZsF
|
|
||||||
bJLcMzNDLbMgwfnGMWFv
|
|
||||||
lpvhmzNDmDmlNbzbmrVVPrHRCPHQBVCP
|
|
||||||
rZllQrsRWrlQswccMVbGbVbTdcQQ
|
|
||||||
NtJCntLSHCjznfLTcGGGqWMdWM
|
|
||||||
jCtzzSFthhSSSjPJrFDlvWrlDZRpwpRZ
|
|
||||||
mQmbLjbrLQjLmTtwwWBTTvWjtt
|
|
||||||
BHSqdHclHHNFlppNqWPwfwDvTfDPPtCw
|
|
||||||
ddSGMGHcdcMhMZnBbmbZmgGJJg
|
|
||||||
lvvBzvDnlzjfPnfjnQPlldRbVbRqbqqCgsqqVpQQgVqc
|
|
||||||
NNFtGNMtTNFmJNGNZtZMwVRTTcsCpVTbbgCbgRhscp
|
|
||||||
FGNGZMtNLWmmJWGFWJGLSNtPrPnBfDzzvjnDBzpnvDBLnv
|
|
||||||
fwvQRFQvQqwpwNJrwN
|
|
||||||
BstDnBjhjBhnshSptpJzWqNppbfr
|
|
||||||
CsDjCdZcBCDcjnfDHfhnfggZMGlgQVmgMTRmgVGMMl
|
|
||||||
MwlBVqVlsgnmzwJsvjhWZhGPvjvRRWzG
|
|
||||||
QNQpQpftHdHHCHGfSpCrQNdSrDRDhchhjvjcPrRRWrPvhZjv
|
|
||||||
LtLSCTSGfHGdGwswnqsggssTqV
|
|
||||||
qDDCHjzjznTvWshZQWfnZZ
|
|
||||||
PFFmmNMMtNMVFtczcFPJNrLhZwQZQsSvvSvWvGQQJQssss
|
|
||||||
tFzrrPPNNFlzVrpRTpblRDqjTpDC
|
|
||||||
DWDrrBdpmdpBrCgDthdtfcHsqJsCqscqwfsjzHcq
|
|
||||||
TNLNFNSTQNQTSnlMcczVJjVzsqLDDfJJ
|
|
||||||
TFPZQRvvlMSPPtRWDtmDRWrBGr
|
|
||||||
LWGVZdrvWdpLGWRsjPMsHmdHdHldlj
|
|
||||||
zJzznChzzzCSfTgMhCPDmlDCbmlsmjDDQj
|
|
||||||
nSTTJhJtnShNtzwhgNrGRRWZZRvMWMtVrqGp
|
|
||||||
PbPmtNmBbPlqBvqlDJBT
|
|
||||||
LpGVDzVpVZqqSTvq
|
|
||||||
pMnWGLRLRppnGpGndrGPtgDCjMPmbPgCQmPPNN
|
|
||||||
sqcZcbZZpcZspcCCRMmznWGWdLWhwDRGTTWggT
|
|
||||||
NjFSJgVHrvfVtrGzWdSznDwLSTLn
|
|
||||||
jFrBNVVjBFNvHrFHBlBFFpMslPgPcpMPmcQPPZCgpP
|
|
||||||
frddqsThtsTfTbPcvhsrbsRLpRBNRpmDpGmRGcRNLpGp
|
|
||||||
QWJHCJwWzlHZQZHQCJJRzRqnLDGRGpnGBRnNDN
|
|
||||||
CVwHCClJjQgWCZVZQgMwSdthjrqvrSPPhdbqtPhs
|
|
||||||
TvdphBBhhhCgdLNNJJJLWz
|
|
||||||
fVcsqRVrPcnJWgDnJN
|
|
||||||
JlqsRJtssZwqwVtPwltRPsHHbFTwTFbpjHhQjTQbvpTF
|
|
||||||
cQSnPDDQJGNzwnNpZb
|
|
||||||
RHDrssVRDHRgsRFHRlrVwzzpNGZlfZdppZdwGNZb
|
|
||||||
sHCHtDgtCjVVLFChqPMhBCMcSTqB
|
|
||||||
hdbQbqcCCQcqFbCbVdcWCQQlRMBtGlRHBtBMpHhpHThZMR
|
|
||||||
LLsSLLfgJPrgPnssnmlZtlZpHGHVGfZVtZpl
|
|
||||||
PvmvgmvvnzmrSsSLJDqDNzqFDQdDwzWWbV
|
|
||||||
HNNjnLbpLGHvWJDhdWWPpWDW
|
|
||||||
lVcSNgcSVclhRlPZPRCDCR
|
|
||||||
cqmSQrwwrrVSrtQFqVNmFwjQnvjHzBbLLGjfjzHTzvnH
|
|
||||||
QmvWVppPHQQvbbvmSHSpPzfzwnWMTZFFzwFMCzLnwT
|
|
||||||
jGBljlNNjgDtGDrNjjtjqqDRnMzRLnFzCFnMfRfMzCnttF
|
|
||||||
jqNrrGdJcdgLjqDqBrDQbbmhdQQmmpPbphmbVv
|
|
||||||
ZHQCggVHHRDWvbfjGptVtLvL
|
|
||||||
nnFwnwrDDMShnhFrFLLLpjvPlPGGtLGb
|
|
||||||
dcNSMhrrTDCBCsWgCTQW
|
|
||||||
HqDDLGtDdCnhfDnwnV
|
|
||||||
PmlJsJTPlbdBTzTnzhnnCCWWzV
|
|
||||||
lSPjMScggsScgjSMMbqHLFGrRLGHRZZtdrcG
|
|
||||||
ZVVtNNppdZSdLtCPqnHhqJJFtb
|
|
||||||
zgwwQBfwmGgSrDfgrrGBggzHCnbJbqbCJFnqhHBhnHHCqJ
|
|
||||||
rvrzfmlRrgDgmrzfggvwzvdjjcccLjMjVcVcsVLjVSZR
|
|
||||||
dppcLRHpphchhNhSddjzHzWQWQLtrMsrWQCWCsMZssCZ
|
|
||||||
JGfBfJJfBqvGVlVbDBwDBDBfZnrQsMQtssMttssDsQMWZncn
|
|
||||||
qPVwlgPBmjpPhcmS
|
|
||||||
zGPnzBgPzPnPlHZlDDHnZBNCvrtcjcjmMcFzNcNFmFdc
|
|
||||||
qQpfsLTTSspqTfJdmdCtMjdtjvJcmr
|
|
||||||
bfQqqSrswLLrfpLTqprfTnDVDVBBbgHPDHnhDPgDbV
|
|
||||||
JssTnsdFztZLdNJnNtTsLNZGqlbGFBqrGMHqHBcFBqMFMH
|
|
||||||
CCgSfgPSvSfhpShSRppCdfrlqGHGGcHmclmqbbqbqlPc
|
|
||||||
wvVSVjQSSQhRVvfQChvZZsdtJstjLNLZDJnLss
|
|
||||||
CmfNNNZNqDrnDjMhZM
|
|
||||||
gdczzGtdFcddtWQgGGMnVhnjJwnrJFDPTwMP
|
|
||||||
dlvcdzdHtzQSLRSfmhLSqv
|
|
||||||
ZpFFLcHFZZRRmJVZgD
|
|
||||||
PzhrtQntzcrjCRJtbtRgBsBRVR
|
|
||||||
zdzWfCzhQzlhWfWhlvpFNlpSqcMSHHMv
|
|
||||||
NrrMgMhNQhNjQrtqtPtwVtZpggPw
|
|
||||||
TfRLndnLFCRFTFbbRDHwpVqqBBwsHwZsfH
|
|
||||||
TJFRdLlRThrlcvZcvQ
|
|
||||||
scrwRVjbQvQBzsBC
|
|
||||||
gMfVqNnVmnCBQDTvdn
|
|
||||||
SMqhWqVlmWSmqMVRSJjjpcFrcLpJrR
|
|
||||||
HtSQHQntHsHMrtHnGfHQVVzLvSBSVvVVSFNJzzVN
|
|
||||||
cmPRmpqlpPmcgTlTpjJNjjVDvDRFNVVBFD
|
|
||||||
hlmCpmqmpgqpZTlcdQHFQfbHHZttwMQwtr
|
|
||||||
VpWgbgfwCjbftwVPPpGQFQhzTBQTBGPzqFTS
|
|
||||||
dbRbDcRrsnsRrLZmLRDZldDZqTNTGqqFFzGGhSTNTFTzNmNT
|
|
||||||
MlLdHlDDHrHclMMrCwgHCCwWwCbCCjjg
|
|
||||||
GGNLhfDMVcVrcGsT
|
|
||||||
jSJQFjHbwPFSvQSHwZFvHSHrqCCrrTsqBwNBrcBNsVTsqq
|
|
||||||
QjZSjZJZPvNRZJQPnSZbJZRWLfnmgDlmhdhWgWLdMdfmhM
|
|
||||||
CgGnzPNggCJtNTgTZTPZzZZvvcDcDDdqDFcJssJDHDqvHq
|
|
||||||
jhhrrLVlmLRRnRflfVbFHHHqdVsDqcvbHVDb
|
|
||||||
jWfWwrlmRRnQmPzZNGZPBNCQTB
|
|
||||||
NzDDhwNmhvtrGmNCvWRVbcRRVTcHHcVFTbwV
|
|
||||||
LgsPlLsQgQdJsLdldtpgFFTMbnFqTcMbHqFcPncq
|
|
||||||
dgsJsLLLggljrhtGNNtSjvGm
|
|
||||||
ptzSrZtzhsmmtPrhLFRFnjnnLMsnfLRL
|
|
||||||
HvwVDHwWWgGDGdHgqVDWDMnRnTjFNTNjfLJvRRRRRR
|
|
||||||
DwDgWgQbDDDHwBBBWdwQGVHhlhlZZSSmztfcppSBhzZcZp
|
|
||||||
CWmWRzlMJqWDWqCJbqDlCBBVLMQHVMGrfMVtQZrsLL
|
|
||||||
SnhPdFFPNZsBBdHtVQ
|
|
||||||
SSPcFFgnwnSpwvcSjwzCqRzTmJbpJCRBmbbD
|
|
||||||
wQbqGWWSqwrbGWWWGjbNMJPfgfnnDmPnPNLfjN
|
|
||||||
tJFztRZCvVRCztZFZRVgmMhmgNLfRfnmDPNPhm
|
|
||||||
BFCVZzpVFlHCdbQqcTcGlJbbSG
|
|
||||||
tttfLPZZQZTlZPHHPWgMVvBnjmvjnjgGBQ
|
|
||||||
FzcNDDDrNzprrrshprhFJtVGVnjtjGvnhvVnnjnjGM
|
|
||||||
RDqJNszDPfdqPtlT
|
|
||||||
QCJdMjCQbdBjSbTHDsbWDDwHTP
|
|
||||||
zlvlmqzqGfgdNzLldrHwwPGpWDrPGZWprr
|
|
||||||
gfVfRczVqcRzmdcSQMjQSQCSjQCQ
|
|
||||||
RhhCGhRBShjjRfpwppFTfFHZHZZD
|
|
||||||
qzdqzlnPPctPdmtPdTZbwQvvwqvHHvZpwZ
|
|
||||||
nVTVTcsWmWSRhhRVrGVB
|
|
||||||
GmshRMnzqRGsPNwMwcrrpcVV
|
|
||||||
CDCbFCLvCgfDSFLslgDpwpLtTwwcPtNNtTTprt
|
|
||||||
JvSFbSbbFllJlgDvlJbgdRhRdqzBGnzshZnRRRnHBZ
|
|
||||||
ShJhtcsvvvQbnnsccVTLVTppWqddpVnLWp
|
|
||||||
NdzPrPZgPMNNrmzpTzpTCjWfzCpzVL
|
|
||||||
dZgHmZRPPZRlZmrPDtDRccvbtQQbJbRS
|
|
||||||
wqjLjwhznhBLqLWGfvSlvcmlrJsqrtJTJJ
|
|
||||||
PwbpFPQDRCDrDJTrTmvs
|
|
||||||
gbZVFbZHgwHbCdpCRMnffNLhWnnzMdzLLW
|
|
||||||
RVVGSNTTRlNqHblBNB
|
|
||||||
JfwJMvLLZwLsMJwWMJfwLHBqzFlvzpBQcqzblFbBqblq
|
|
||||||
wMCZJsgJCCCnsMHrgLLjSPSVTgShtRjTPhRRmt
|
|
||||||
lmQSSWdMHHLWgWqD
|
|
||||||
ZZtVGGGJrJvGVCwfgHNLccmNFFcqtc
|
|
||||||
vrCGPhvrTPdRBnsRTmmp
|
|
||||||
dDMDDjzCQjwCCcDgjSLLLsLNlmpplN
|
|
||||||
FqrHFTFRLCLVFBmS
|
|
||||||
JhHJhHRThrfPZPvhnTZZbWdwdwDDWtDzJDtbMtCW
|
|
||||||
ghwDzJRDwHmPthncSPncLLsPcvnv
|
|
||||||
MWCrNTCHrMVjQQMQcSdnpTLnFFdTcnTc
|
|
||||||
qbWMfWfNrWVQWfbjVBbqMfwDtqzmhmRRzGhtHhHhRwZh
|
|
||||||
fmSmnjTjrlzGlTzJdH
|
|
||||||
BrhRRQMrgQvgFFhQQbwpFvGGdZqZJqpJqHVpJGJLHdLJ
|
|
||||||
ggbDwQMsvsMQrFMFcWSPSCPmSsPfnnmP
|
|
||||||
cmNVbMrrrjcHDRcvfW
|
|
||||||
wQGdFfSThFsLhhHWvDCWDCJRCCjd
|
|
||||||
LtpStGhqrrpnfnpp
|
|
||||||
bvcccTqbgvpGndJtgdsgNd
|
|
||||||
wDQwQhtQhQRmSmjsJndJdBBJBJnlLS
|
|
||||||
hwhmRrzFVjtwzDmrVFrvPCcCMVPPvfqpCCTVVb
|
|
||||||
jRrRNPNRWjPRWPRQNjQjThTCzBBzDCFBGzgDFGGQ
|
|
||||||
dnppLwmwCnvtlqltvtnTGBThGhdFZhgzDzGccD
|
|
||||||
MvnqpLlMqCqCHMjWPPHMSHSs
|
|
||||||
NNpNNvpvBdtTrMFFMhSSwzjzchzwhzwL
|
|
||||||
VVndHqflQZZZgHSLLhjzRSmZRhcR
|
|
||||||
glGgnqbQlngnWCGJpJprtrtFrdPPGs
|
|
||||||
WqwRjzGtRzZZRRGjWBJzjwmfMTHGGssTTDsrLmmmQLMD
|
|
||||||
SNdvSdFlSNNhSPFFcPFclbQQslHmfHTDsTQMLgDTmHQQ
|
|
||||||
CNcCFvpdnWpjWwJf
|
|
||||||
PVPnVHcnRncGZqbVzHVPnnLbSMjwrzWMjSwDtWwWtwWhwDWz
|
|
||||||
pTfsQCshCllpglWWSjBMSQSrMrjM
|
|
||||||
hvpvppggCpJTvTmshgfsmZRRHqbcLPHZmPLRnmPZ
|
|
||||||
LQbhVZZmZhZjBdbGmgHqnHTmvqgnnWHr
|
|
||||||
SzCfDFFNRfsSFFMFfvprvpWzqzgqTwHTvp
|
|
||||||
CDNDFJgMDSQhjVdPJLQG
|
|
||||||
plpdLdpjjrrHJJjLrrHLFdbzzCcvzgFgcwggzPMFvvcMhM
|
|
||||||
GRtSBQNsQlMPRzRlzw
|
|
||||||
ZSTtsmBlmjLLpnpH
|
|
||||||
hglGNVSdNSghzSgCBhDFLBMBtFMMFtHtbtLL
|
|
||||||
frQZccRcqGFmFHrJ
|
|
||||||
nvfGZwvTwGTfQwvfTwfgnCSlpdnzgzslppCsCV
|
|
||||||
snTSPbQnTTnQgbmsTJsLfZwjffhpLnGRjpGfjL
|
|
||||||
dcNWcNHHlNtWHHlCtltWNFNMLZwjpGfpmrZfrFprrRGpwZfp
|
|
||||||
HmdNWCmDMVvQPDgqJs
|
|
||||||
GGFtSngQLfnSnQffgPnRgFRGRwmRJvwbBbJDwjvTbjrwhJvJ
|
|
||||||
WHClslcNNWcqNWlCZdcHsVrThBwBjbhDTDBhrvDZJTwm
|
|
||||||
NWVqqcHHNpsNcNVdVlhCMlHQQMQQzLfzQPttFGPMLSLgtF
|
|
@ -1,57 +0,0 @@
|
|||||||
const std = @import("std");
|
|
||||||
|
|
||||||
const lcConversion = 'a';
|
|
||||||
const ucConversion = 'A' - 26;
|
|
||||||
|
|
||||||
const charIndexer = struct {
|
|
||||||
pub const Key = u8;
|
|
||||||
pub const count: usize = 52;
|
|
||||||
pub fn indexOf(e: u8) usize {
|
|
||||||
return letterToIdx(e);
|
|
||||||
}
|
|
||||||
pub fn keyForIndex(i: usize) u8 {
|
|
||||||
return idxToLetter(i);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
const CharSet: type = std.enums.IndexedSet(charIndexer, std.enums.NoExtension);
|
|
||||||
|
|
||||||
fn letterToIdx(char: u8) u8 {
|
|
||||||
return switch (char) {
|
|
||||||
'a'...'z' => char - lcConversion,
|
|
||||||
'A'...'Z' => char - ucConversion,
|
|
||||||
else => unreachable,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
fn idxToLetter(i: usize) u8 {
|
|
||||||
const char = @intCast(u8, i);
|
|
||||||
return if (char < 26) char + lcConversion else char + ucConversion;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn main() !void {
|
|
||||||
var file = try std.fs.cwd().openFile("input.txt", .{});
|
|
||||||
defer file.close();
|
|
||||||
|
|
||||||
var a = std.io.bufferedReader(file.reader());
|
|
||||||
var readerStream = a.reader();
|
|
||||||
|
|
||||||
var buf: [200]u8 = undefined;
|
|
||||||
var score: i32 = 0;
|
|
||||||
while (try readerStream.readUntilDelimiterOrEof(&buf, '\n')) |line| {
|
|
||||||
var bagOne: CharSet = .{};
|
|
||||||
var bagTwo: CharSet = .{};
|
|
||||||
var i: u32 = 0;
|
|
||||||
while (i < line.len / 2) : (i += 1) {
|
|
||||||
bagOne.setPresent(line[i], true);
|
|
||||||
}
|
|
||||||
while (i < line.len) : (i += 1) {
|
|
||||||
bagTwo.setPresent(line[i], true);
|
|
||||||
}
|
|
||||||
bagOne.setIntersection(bagTwo);
|
|
||||||
if (bagOne.count() != 1) unreachable; // ensure only one element in common
|
|
||||||
var iter = bagOne.iterator();
|
|
||||||
score += letterToIdx(iter.next().?) + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
std.debug.print("{d}\n", .{score});
|
|
||||||
}
|
|
@ -1,58 +0,0 @@
|
|||||||
const std = @import("std");
|
|
||||||
|
|
||||||
const lcConversion = 'a';
|
|
||||||
const ucConversion = 'A' - 26;
|
|
||||||
|
|
||||||
const charIndexer = struct {
|
|
||||||
pub const Key = u8;
|
|
||||||
pub const count: usize = 52;
|
|
||||||
pub fn indexOf(e: u8) usize {
|
|
||||||
return letterToIdx(e);
|
|
||||||
}
|
|
||||||
pub fn keyForIndex(i: usize) u8 {
|
|
||||||
return idxToLetter(i);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
const CharSet: type = std.enums.IndexedSet(charIndexer, std.enums.NoExtension);
|
|
||||||
|
|
||||||
fn letterToIdx(char: u8) u8 {
|
|
||||||
return switch (char) {
|
|
||||||
'a'...'z' => char - lcConversion,
|
|
||||||
'A'...'Z' => char - ucConversion,
|
|
||||||
else => unreachable,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
fn idxToLetter(i: usize) u8 {
|
|
||||||
const char = @intCast(u8, i);
|
|
||||||
return if (char < 26) char + lcConversion else char + ucConversion;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn main() !void {
|
|
||||||
var file = try std.fs.cwd().openFile("input.txt", .{});
|
|
||||||
defer file.close();
|
|
||||||
|
|
||||||
var a = std.io.bufferedReader(file.reader());
|
|
||||||
var readerStream = a.reader();
|
|
||||||
|
|
||||||
var buf: [200]u8 = undefined;
|
|
||||||
var score: i32 = 0;
|
|
||||||
read: while (true) {
|
|
||||||
var bags = [_]CharSet{ .{}, .{}, .{} };
|
|
||||||
for (bags) |*bag| {
|
|
||||||
const maybeLine = try readerStream.readUntilDelimiterOrEof(&buf, '\n');
|
|
||||||
if (maybeLine) |line| {
|
|
||||||
for (line) |char| {
|
|
||||||
bag.setPresent(char, true);
|
|
||||||
}
|
|
||||||
} else break :read;
|
|
||||||
}
|
|
||||||
bags[0].setIntersection(bags[1]);
|
|
||||||
bags[0].setIntersection(bags[2]);
|
|
||||||
if (bags[0].count() != 1) unreachable; // ensure only one element in common
|
|
||||||
var iter = bags[0].iterator();
|
|
||||||
score += letterToIdx(iter.next().?) + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
std.debug.print("{d}\n", .{score});
|
|
||||||
}
|
|
1000
zig/4/input.txt
1000
zig/4/input.txt
File diff suppressed because it is too large
Load Diff
@ -1,38 +0,0 @@
|
|||||||
const std = @import("std");
|
|
||||||
|
|
||||||
const Pair = struct {
|
|
||||||
low: i32 = 0,
|
|
||||||
high: i32 = 0,
|
|
||||||
fn fullyOverlaps(self: *Pair, other: *Pair) bool {
|
|
||||||
return (self.low <= other.low and self.high >= other.high) or (self.low >= other.low and self.high <= other.high);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
fn parsei32Guaranteed(str: []const u8) i32 {
|
|
||||||
return std.fmt.parseInt(i32, str, 10) catch unreachable;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn main() !void {
|
|
||||||
var file = try std.fs.cwd().openFile("input.txt", .{});
|
|
||||||
defer file.close();
|
|
||||||
|
|
||||||
var a = std.io.bufferedReader(file.reader());
|
|
||||||
var readerStream = a.reader();
|
|
||||||
|
|
||||||
var count: i32 = 0;
|
|
||||||
var buf: [32]u8 = undefined;
|
|
||||||
while (try readerStream.readUntilDelimiterOrEof(&buf, '\n')) |line| {
|
|
||||||
var pairStrings = std.mem.split(u8, line, ",");
|
|
||||||
var pairs = [_]Pair{ .{}, .{} };
|
|
||||||
for (pairs) |*pair| {
|
|
||||||
var elements = std.mem.split(u8, pairStrings.next().?, "-");
|
|
||||||
pair.low = parsei32Guaranteed(elements.next().?);
|
|
||||||
pair.high = parsei32Guaranteed(elements.next().?);
|
|
||||||
}
|
|
||||||
if (pairs[0].fullyOverlaps(&pairs[1])) {
|
|
||||||
count += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std.debug.print("{d}\n", .{count});
|
|
||||||
}
|
|
@ -1,41 +0,0 @@
|
|||||||
const std = @import("std");
|
|
||||||
|
|
||||||
const Pair = struct {
|
|
||||||
low: i32 = 0,
|
|
||||||
high: i32 = 0,
|
|
||||||
fn fullyOverlaps(self: *Pair, other: *Pair) bool {
|
|
||||||
return (self.low <= other.low and self.high >= other.high) or (self.low >= other.low and self.high <= other.high);
|
|
||||||
}
|
|
||||||
fn partiallyOverlaps(self: *Pair, other: *Pair) bool {
|
|
||||||
return (self.low <= other.high and self.high >= other.low);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
fn parsei32Guaranteed(str: []const u8) i32 {
|
|
||||||
return std.fmt.parseInt(i32, str, 10) catch unreachable;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn main() !void {
|
|
||||||
var file = try std.fs.cwd().openFile("input.txt", .{});
|
|
||||||
defer file.close();
|
|
||||||
|
|
||||||
var a = std.io.bufferedReader(file.reader());
|
|
||||||
var readerStream = a.reader();
|
|
||||||
|
|
||||||
var count: i32 = 0;
|
|
||||||
var buf: [32]u8 = undefined;
|
|
||||||
while (try readerStream.readUntilDelimiterOrEof(&buf, '\n')) |line| {
|
|
||||||
var pairStrings = std.mem.split(u8, line, ",");
|
|
||||||
var pairs = [_]Pair{ .{}, .{} };
|
|
||||||
for (pairs) |*pair| {
|
|
||||||
var elements = std.mem.split(u8, pairStrings.next().?, "-");
|
|
||||||
pair.low = parsei32Guaranteed(elements.next().?);
|
|
||||||
pair.high = parsei32Guaranteed(elements.next().?);
|
|
||||||
}
|
|
||||||
if (pairs[0].partiallyOverlaps(&pairs[1])) {
|
|
||||||
count += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std.debug.print("{d}\n", .{count});
|
|
||||||
}
|
|
512
zig/5/input.txt
512
zig/5/input.txt
@ -1,512 +0,0 @@
|
|||||||
[T] [D] [L]
|
|
||||||
[R] [S] [G] [P] [H]
|
|
||||||
[G] [H] [W] [R] [L] [P]
|
|
||||||
[W] [G] [F] [H] [S] [M] [L]
|
|
||||||
[Q] [V] [B] [J] [H] [N] [R] [N]
|
|
||||||
[M] [R] [R] [P] [M] [T] [H] [Q] [C]
|
|
||||||
[F] [F] [Z] [H] [S] [Z] [T] [D] [S]
|
|
||||||
[P] [H] [P] [Q] [P] [M] [P] [F] [D]
|
|
||||||
1 2 3 4 5 6 7 8 9
|
|
||||||
|
|
||||||
move 3 from 8 to 9
|
|
||||||
move 2 from 2 to 8
|
|
||||||
move 5 from 4 to 2
|
|
||||||
move 7 from 1 to 4
|
|
||||||
move 3 from 8 to 2
|
|
||||||
move 3 from 2 to 7
|
|
||||||
move 1 from 7 to 4
|
|
||||||
move 3 from 2 to 9
|
|
||||||
move 4 from 7 to 9
|
|
||||||
move 1 from 5 to 2
|
|
||||||
move 2 from 3 to 4
|
|
||||||
move 5 from 9 to 5
|
|
||||||
move 6 from 9 to 3
|
|
||||||
move 5 from 9 to 5
|
|
||||||
move 1 from 9 to 7
|
|
||||||
move 2 from 3 to 1
|
|
||||||
move 7 from 3 to 9
|
|
||||||
move 2 from 7 to 2
|
|
||||||
move 5 from 2 to 4
|
|
||||||
move 1 from 2 to 9
|
|
||||||
move 2 from 1 to 9
|
|
||||||
move 7 from 6 to 1
|
|
||||||
move 2 from 7 to 3
|
|
||||||
move 2 from 3 to 9
|
|
||||||
move 1 from 7 to 4
|
|
||||||
move 1 from 9 to 2
|
|
||||||
move 3 from 1 to 8
|
|
||||||
move 2 from 3 to 4
|
|
||||||
move 5 from 9 to 2
|
|
||||||
move 1 from 3 to 9
|
|
||||||
move 8 from 5 to 7
|
|
||||||
move 1 from 6 to 1
|
|
||||||
move 15 from 4 to 1
|
|
||||||
move 4 from 2 to 5
|
|
||||||
move 5 from 9 to 7
|
|
||||||
move 1 from 9 to 5
|
|
||||||
move 5 from 1 to 2
|
|
||||||
move 3 from 8 to 9
|
|
||||||
move 1 from 7 to 6
|
|
||||||
move 11 from 1 to 2
|
|
||||||
move 7 from 5 to 3
|
|
||||||
move 4 from 2 to 6
|
|
||||||
move 7 from 3 to 4
|
|
||||||
move 3 from 5 to 9
|
|
||||||
move 2 from 2 to 5
|
|
||||||
move 5 from 1 to 8
|
|
||||||
move 2 from 6 to 8
|
|
||||||
move 3 from 8 to 9
|
|
||||||
move 9 from 4 to 9
|
|
||||||
move 9 from 7 to 4
|
|
||||||
move 2 from 8 to 1
|
|
||||||
move 1 from 8 to 7
|
|
||||||
move 6 from 2 to 7
|
|
||||||
move 5 from 2 to 4
|
|
||||||
move 5 from 7 to 2
|
|
||||||
move 2 from 1 to 7
|
|
||||||
move 2 from 6 to 4
|
|
||||||
move 7 from 7 to 1
|
|
||||||
move 3 from 2 to 6
|
|
||||||
move 1 from 8 to 7
|
|
||||||
move 2 from 9 to 3
|
|
||||||
move 2 from 3 to 1
|
|
||||||
move 1 from 2 to 5
|
|
||||||
move 4 from 6 to 5
|
|
||||||
move 2 from 2 to 3
|
|
||||||
move 3 from 5 to 7
|
|
||||||
move 1 from 5 to 3
|
|
||||||
move 9 from 1 to 7
|
|
||||||
move 2 from 9 to 5
|
|
||||||
move 13 from 4 to 1
|
|
||||||
move 5 from 7 to 2
|
|
||||||
move 3 from 3 to 1
|
|
||||||
move 2 from 2 to 9
|
|
||||||
move 1 from 2 to 7
|
|
||||||
move 5 from 5 to 6
|
|
||||||
move 2 from 2 to 4
|
|
||||||
move 5 from 1 to 3
|
|
||||||
move 9 from 7 to 8
|
|
||||||
move 2 from 9 to 5
|
|
||||||
move 3 from 5 to 4
|
|
||||||
move 5 from 9 to 2
|
|
||||||
move 10 from 4 to 8
|
|
||||||
move 1 from 4 to 1
|
|
||||||
move 2 from 8 to 4
|
|
||||||
move 4 from 8 to 2
|
|
||||||
move 3 from 6 to 8
|
|
||||||
move 7 from 8 to 7
|
|
||||||
move 10 from 9 to 3
|
|
||||||
move 7 from 3 to 2
|
|
||||||
move 11 from 2 to 3
|
|
||||||
move 13 from 3 to 9
|
|
||||||
move 1 from 6 to 3
|
|
||||||
move 1 from 1 to 2
|
|
||||||
move 1 from 2 to 8
|
|
||||||
move 3 from 3 to 4
|
|
||||||
move 1 from 2 to 9
|
|
||||||
move 1 from 4 to 1
|
|
||||||
move 10 from 8 to 3
|
|
||||||
move 11 from 9 to 7
|
|
||||||
move 1 from 6 to 2
|
|
||||||
move 14 from 7 to 1
|
|
||||||
move 2 from 2 to 9
|
|
||||||
move 4 from 7 to 6
|
|
||||||
move 1 from 2 to 4
|
|
||||||
move 3 from 4 to 2
|
|
||||||
move 4 from 2 to 9
|
|
||||||
move 10 from 3 to 4
|
|
||||||
move 3 from 6 to 1
|
|
||||||
move 5 from 9 to 5
|
|
||||||
move 5 from 5 to 8
|
|
||||||
move 1 from 9 to 7
|
|
||||||
move 2 from 9 to 6
|
|
||||||
move 1 from 9 to 8
|
|
||||||
move 2 from 4 to 8
|
|
||||||
move 1 from 4 to 5
|
|
||||||
move 2 from 3 to 1
|
|
||||||
move 2 from 3 to 7
|
|
||||||
move 27 from 1 to 2
|
|
||||||
move 2 from 7 to 1
|
|
||||||
move 9 from 4 to 6
|
|
||||||
move 9 from 6 to 5
|
|
||||||
move 5 from 8 to 6
|
|
||||||
move 26 from 2 to 3
|
|
||||||
move 1 from 2 to 5
|
|
||||||
move 1 from 2 to 7
|
|
||||||
move 1 from 8 to 4
|
|
||||||
move 1 from 7 to 8
|
|
||||||
move 24 from 3 to 5
|
|
||||||
move 1 from 8 to 5
|
|
||||||
move 1 from 4 to 3
|
|
||||||
move 1 from 7 to 1
|
|
||||||
move 1 from 8 to 9
|
|
||||||
move 7 from 1 to 7
|
|
||||||
move 8 from 6 to 4
|
|
||||||
move 4 from 7 to 6
|
|
||||||
move 1 from 3 to 9
|
|
||||||
move 2 from 9 to 1
|
|
||||||
move 3 from 7 to 9
|
|
||||||
move 8 from 4 to 6
|
|
||||||
move 3 from 9 to 1
|
|
||||||
move 1 from 3 to 6
|
|
||||||
move 1 from 8 to 2
|
|
||||||
move 10 from 5 to 4
|
|
||||||
move 1 from 3 to 8
|
|
||||||
move 13 from 5 to 3
|
|
||||||
move 1 from 2 to 9
|
|
||||||
move 1 from 8 to 9
|
|
||||||
move 1 from 3 to 8
|
|
||||||
move 1 from 9 to 2
|
|
||||||
move 3 from 6 to 9
|
|
||||||
move 7 from 4 to 9
|
|
||||||
move 4 from 3 to 9
|
|
||||||
move 2 from 6 to 8
|
|
||||||
move 2 from 4 to 5
|
|
||||||
move 10 from 9 to 3
|
|
||||||
move 1 from 1 to 9
|
|
||||||
move 1 from 4 to 8
|
|
||||||
move 1 from 1 to 4
|
|
||||||
move 1 from 4 to 5
|
|
||||||
move 4 from 6 to 3
|
|
||||||
move 1 from 9 to 5
|
|
||||||
move 1 from 6 to 9
|
|
||||||
move 2 from 6 to 5
|
|
||||||
move 1 from 9 to 2
|
|
||||||
move 1 from 6 to 7
|
|
||||||
move 18 from 5 to 2
|
|
||||||
move 22 from 3 to 7
|
|
||||||
move 19 from 7 to 1
|
|
||||||
move 3 from 8 to 5
|
|
||||||
move 4 from 9 to 3
|
|
||||||
move 2 from 7 to 2
|
|
||||||
move 1 from 8 to 1
|
|
||||||
move 19 from 1 to 3
|
|
||||||
move 2 from 7 to 5
|
|
||||||
move 13 from 3 to 9
|
|
||||||
move 4 from 1 to 2
|
|
||||||
move 3 from 5 to 1
|
|
||||||
move 11 from 9 to 1
|
|
||||||
move 11 from 2 to 8
|
|
||||||
move 3 from 9 to 3
|
|
||||||
move 3 from 5 to 2
|
|
||||||
move 2 from 1 to 4
|
|
||||||
move 5 from 2 to 7
|
|
||||||
move 12 from 1 to 5
|
|
||||||
move 2 from 4 to 5
|
|
||||||
move 9 from 5 to 8
|
|
||||||
move 1 from 5 to 3
|
|
||||||
move 4 from 2 to 3
|
|
||||||
move 2 from 7 to 5
|
|
||||||
move 6 from 2 to 8
|
|
||||||
move 17 from 8 to 9
|
|
||||||
move 2 from 9 to 6
|
|
||||||
move 2 from 7 to 1
|
|
||||||
move 15 from 9 to 6
|
|
||||||
move 2 from 2 to 4
|
|
||||||
move 9 from 8 to 5
|
|
||||||
move 2 from 1 to 3
|
|
||||||
move 12 from 6 to 2
|
|
||||||
move 2 from 3 to 9
|
|
||||||
move 5 from 6 to 3
|
|
||||||
move 4 from 5 to 3
|
|
||||||
move 11 from 3 to 4
|
|
||||||
move 2 from 9 to 4
|
|
||||||
move 6 from 5 to 2
|
|
||||||
move 13 from 4 to 3
|
|
||||||
move 1 from 4 to 5
|
|
||||||
move 1 from 4 to 8
|
|
||||||
move 18 from 2 to 6
|
|
||||||
move 2 from 5 to 3
|
|
||||||
move 1 from 8 to 3
|
|
||||||
move 1 from 2 to 5
|
|
||||||
move 1 from 7 to 8
|
|
||||||
move 28 from 3 to 6
|
|
||||||
move 2 from 3 to 4
|
|
||||||
move 3 from 5 to 9
|
|
||||||
move 2 from 5 to 9
|
|
||||||
move 3 from 9 to 3
|
|
||||||
move 5 from 3 to 4
|
|
||||||
move 1 from 9 to 3
|
|
||||||
move 1 from 9 to 1
|
|
||||||
move 1 from 3 to 4
|
|
||||||
move 45 from 6 to 2
|
|
||||||
move 1 from 8 to 3
|
|
||||||
move 2 from 4 to 6
|
|
||||||
move 5 from 4 to 2
|
|
||||||
move 1 from 3 to 7
|
|
||||||
move 3 from 2 to 9
|
|
||||||
move 1 from 4 to 8
|
|
||||||
move 3 from 6 to 1
|
|
||||||
move 42 from 2 to 8
|
|
||||||
move 2 from 9 to 2
|
|
||||||
move 4 from 2 to 6
|
|
||||||
move 2 from 2 to 7
|
|
||||||
move 1 from 9 to 6
|
|
||||||
move 2 from 8 to 9
|
|
||||||
move 4 from 1 to 8
|
|
||||||
move 1 from 6 to 4
|
|
||||||
move 1 from 4 to 8
|
|
||||||
move 1 from 2 to 5
|
|
||||||
move 3 from 7 to 4
|
|
||||||
move 39 from 8 to 3
|
|
||||||
move 7 from 8 to 5
|
|
||||||
move 8 from 5 to 7
|
|
||||||
move 35 from 3 to 1
|
|
||||||
move 4 from 3 to 7
|
|
||||||
move 10 from 7 to 2
|
|
||||||
move 2 from 9 to 6
|
|
||||||
move 3 from 4 to 2
|
|
||||||
move 1 from 7 to 5
|
|
||||||
move 1 from 7 to 8
|
|
||||||
move 1 from 5 to 4
|
|
||||||
move 12 from 1 to 6
|
|
||||||
move 1 from 8 to 1
|
|
||||||
move 1 from 4 to 5
|
|
||||||
move 14 from 6 to 8
|
|
||||||
move 9 from 8 to 6
|
|
||||||
move 5 from 6 to 1
|
|
||||||
move 11 from 2 to 9
|
|
||||||
move 1 from 9 to 8
|
|
||||||
move 6 from 8 to 3
|
|
||||||
move 6 from 9 to 2
|
|
||||||
move 8 from 1 to 9
|
|
||||||
move 3 from 3 to 6
|
|
||||||
move 7 from 1 to 4
|
|
||||||
move 1 from 5 to 9
|
|
||||||
move 8 from 9 to 8
|
|
||||||
move 7 from 6 to 8
|
|
||||||
move 1 from 9 to 3
|
|
||||||
move 3 from 6 to 4
|
|
||||||
move 3 from 9 to 1
|
|
||||||
move 4 from 3 to 2
|
|
||||||
move 1 from 6 to 7
|
|
||||||
move 1 from 4 to 2
|
|
||||||
move 13 from 1 to 7
|
|
||||||
move 6 from 4 to 8
|
|
||||||
move 1 from 7 to 3
|
|
||||||
move 1 from 4 to 6
|
|
||||||
move 1 from 9 to 5
|
|
||||||
move 1 from 3 to 5
|
|
||||||
move 19 from 8 to 9
|
|
||||||
move 1 from 6 to 5
|
|
||||||
move 6 from 9 to 2
|
|
||||||
move 2 from 5 to 8
|
|
||||||
move 1 from 5 to 2
|
|
||||||
move 4 from 1 to 4
|
|
||||||
move 8 from 9 to 4
|
|
||||||
move 3 from 9 to 8
|
|
||||||
move 2 from 9 to 1
|
|
||||||
move 6 from 7 to 5
|
|
||||||
move 12 from 4 to 2
|
|
||||||
move 6 from 8 to 3
|
|
||||||
move 1 from 4 to 1
|
|
||||||
move 1 from 3 to 1
|
|
||||||
move 13 from 2 to 3
|
|
||||||
move 4 from 5 to 3
|
|
||||||
move 1 from 4 to 9
|
|
||||||
move 1 from 8 to 9
|
|
||||||
move 12 from 3 to 2
|
|
||||||
move 1 from 9 to 1
|
|
||||||
move 2 from 5 to 9
|
|
||||||
move 3 from 9 to 5
|
|
||||||
move 1 from 7 to 5
|
|
||||||
move 3 from 7 to 3
|
|
||||||
move 1 from 5 to 4
|
|
||||||
move 1 from 5 to 8
|
|
||||||
move 9 from 2 to 3
|
|
||||||
move 2 from 2 to 3
|
|
||||||
move 3 from 1 to 9
|
|
||||||
move 1 from 8 to 9
|
|
||||||
move 3 from 9 to 1
|
|
||||||
move 9 from 2 to 6
|
|
||||||
move 1 from 9 to 5
|
|
||||||
move 6 from 2 to 3
|
|
||||||
move 2 from 6 to 9
|
|
||||||
move 3 from 6 to 3
|
|
||||||
move 1 from 4 to 3
|
|
||||||
move 2 from 9 to 6
|
|
||||||
move 2 from 7 to 2
|
|
||||||
move 2 from 2 to 8
|
|
||||||
move 24 from 3 to 7
|
|
||||||
move 2 from 5 to 6
|
|
||||||
move 2 from 8 to 2
|
|
||||||
move 7 from 2 to 8
|
|
||||||
move 8 from 3 to 6
|
|
||||||
move 2 from 1 to 3
|
|
||||||
move 1 from 1 to 2
|
|
||||||
move 1 from 5 to 2
|
|
||||||
move 15 from 7 to 4
|
|
||||||
move 9 from 7 to 9
|
|
||||||
move 7 from 9 to 1
|
|
||||||
move 5 from 8 to 1
|
|
||||||
move 4 from 1 to 4
|
|
||||||
move 19 from 4 to 3
|
|
||||||
move 22 from 3 to 5
|
|
||||||
move 1 from 7 to 5
|
|
||||||
move 9 from 5 to 4
|
|
||||||
move 6 from 1 to 3
|
|
||||||
move 6 from 3 to 1
|
|
||||||
move 4 from 5 to 4
|
|
||||||
move 1 from 2 to 1
|
|
||||||
move 1 from 2 to 6
|
|
||||||
move 4 from 6 to 1
|
|
||||||
move 1 from 3 to 6
|
|
||||||
move 3 from 6 to 3
|
|
||||||
move 2 from 9 to 8
|
|
||||||
move 2 from 5 to 3
|
|
||||||
move 2 from 5 to 1
|
|
||||||
move 10 from 6 to 4
|
|
||||||
move 4 from 4 to 9
|
|
||||||
move 7 from 4 to 3
|
|
||||||
move 2 from 8 to 7
|
|
||||||
move 4 from 9 to 3
|
|
||||||
move 5 from 5 to 7
|
|
||||||
move 1 from 5 to 1
|
|
||||||
move 1 from 6 to 3
|
|
||||||
move 1 from 8 to 4
|
|
||||||
move 1 from 8 to 3
|
|
||||||
move 13 from 4 to 5
|
|
||||||
move 1 from 1 to 8
|
|
||||||
move 6 from 5 to 3
|
|
||||||
move 1 from 7 to 6
|
|
||||||
move 5 from 7 to 6
|
|
||||||
move 9 from 1 to 8
|
|
||||||
move 1 from 8 to 4
|
|
||||||
move 1 from 7 to 1
|
|
||||||
move 1 from 4 to 1
|
|
||||||
move 5 from 3 to 7
|
|
||||||
move 3 from 7 to 9
|
|
||||||
move 1 from 5 to 4
|
|
||||||
move 6 from 8 to 6
|
|
||||||
move 1 from 9 to 3
|
|
||||||
move 2 from 9 to 5
|
|
||||||
move 7 from 5 to 9
|
|
||||||
move 1 from 7 to 5
|
|
||||||
move 2 from 5 to 3
|
|
||||||
move 10 from 6 to 8
|
|
||||||
move 2 from 6 to 1
|
|
||||||
move 1 from 4 to 9
|
|
||||||
move 1 from 7 to 5
|
|
||||||
move 8 from 8 to 2
|
|
||||||
move 1 from 1 to 7
|
|
||||||
move 1 from 9 to 7
|
|
||||||
move 1 from 5 to 1
|
|
||||||
move 3 from 9 to 8
|
|
||||||
move 7 from 8 to 7
|
|
||||||
move 6 from 7 to 1
|
|
||||||
move 1 from 8 to 7
|
|
||||||
move 4 from 7 to 1
|
|
||||||
move 16 from 3 to 7
|
|
||||||
move 4 from 3 to 1
|
|
||||||
move 5 from 7 to 8
|
|
||||||
move 16 from 1 to 4
|
|
||||||
move 9 from 1 to 7
|
|
||||||
move 1 from 3 to 4
|
|
||||||
move 15 from 4 to 8
|
|
||||||
move 1 from 3 to 1
|
|
||||||
move 2 from 1 to 6
|
|
||||||
move 2 from 4 to 9
|
|
||||||
move 17 from 8 to 2
|
|
||||||
move 6 from 9 to 5
|
|
||||||
move 8 from 7 to 8
|
|
||||||
move 2 from 6 to 9
|
|
||||||
move 4 from 5 to 7
|
|
||||||
move 2 from 8 to 5
|
|
||||||
move 1 from 5 to 9
|
|
||||||
move 11 from 2 to 6
|
|
||||||
move 4 from 6 to 1
|
|
||||||
move 5 from 2 to 8
|
|
||||||
move 2 from 9 to 2
|
|
||||||
move 1 from 9 to 3
|
|
||||||
move 3 from 1 to 8
|
|
||||||
move 1 from 3 to 6
|
|
||||||
move 7 from 6 to 9
|
|
||||||
move 2 from 5 to 4
|
|
||||||
move 6 from 7 to 4
|
|
||||||
move 4 from 8 to 1
|
|
||||||
move 1 from 5 to 2
|
|
||||||
move 1 from 6 to 1
|
|
||||||
move 7 from 9 to 8
|
|
||||||
move 2 from 7 to 9
|
|
||||||
move 9 from 2 to 9
|
|
||||||
move 5 from 9 to 3
|
|
||||||
move 3 from 2 to 8
|
|
||||||
move 4 from 8 to 7
|
|
||||||
move 9 from 7 to 2
|
|
||||||
move 3 from 1 to 3
|
|
||||||
move 14 from 8 to 1
|
|
||||||
move 2 from 8 to 3
|
|
||||||
move 1 from 9 to 4
|
|
||||||
move 3 from 7 to 9
|
|
||||||
move 8 from 3 to 9
|
|
||||||
move 2 from 2 to 7
|
|
||||||
move 12 from 1 to 8
|
|
||||||
move 4 from 1 to 6
|
|
||||||
move 2 from 6 to 7
|
|
||||||
move 1 from 6 to 7
|
|
||||||
move 9 from 4 to 7
|
|
||||||
move 9 from 7 to 4
|
|
||||||
move 1 from 1 to 6
|
|
||||||
move 2 from 3 to 6
|
|
||||||
move 2 from 6 to 8
|
|
||||||
move 12 from 9 to 8
|
|
||||||
move 2 from 6 to 9
|
|
||||||
move 2 from 9 to 7
|
|
||||||
move 1 from 8 to 5
|
|
||||||
move 5 from 7 to 5
|
|
||||||
move 1 from 9 to 1
|
|
||||||
move 3 from 4 to 1
|
|
||||||
move 5 from 4 to 8
|
|
||||||
move 4 from 1 to 7
|
|
||||||
move 1 from 4 to 2
|
|
||||||
move 19 from 8 to 4
|
|
||||||
move 2 from 7 to 5
|
|
||||||
move 14 from 8 to 5
|
|
||||||
move 2 from 7 to 8
|
|
||||||
move 3 from 9 to 8
|
|
||||||
move 19 from 4 to 2
|
|
||||||
move 9 from 2 to 4
|
|
||||||
move 2 from 7 to 8
|
|
||||||
move 15 from 5 to 9
|
|
||||||
move 15 from 9 to 8
|
|
||||||
move 1 from 5 to 9
|
|
||||||
move 11 from 8 to 7
|
|
||||||
move 4 from 5 to 8
|
|
||||||
move 1 from 5 to 9
|
|
||||||
move 2 from 9 to 5
|
|
||||||
move 2 from 2 to 6
|
|
||||||
move 14 from 2 to 9
|
|
||||||
move 12 from 8 to 9
|
|
||||||
move 3 from 8 to 4
|
|
||||||
move 7 from 9 to 2
|
|
||||||
move 4 from 7 to 9
|
|
||||||
move 1 from 6 to 9
|
|
||||||
move 1 from 7 to 5
|
|
||||||
move 1 from 6 to 2
|
|
||||||
move 3 from 5 to 4
|
|
||||||
move 19 from 9 to 4
|
|
||||||
move 1 from 5 to 1
|
|
||||||
move 1 from 9 to 8
|
|
||||||
move 1 from 1 to 7
|
|
||||||
move 1 from 8 to 9
|
|
||||||
move 4 from 7 to 2
|
|
||||||
move 3 from 7 to 6
|
|
||||||
move 18 from 4 to 2
|
|
||||||
move 17 from 2 to 3
|
|
||||||
move 2 from 6 to 8
|
|
||||||
move 17 from 3 to 6
|
|
||||||
move 13 from 2 to 1
|
|
||||||
move 2 from 8 to 3
|
|
||||||
move 2 from 2 to 9
|
|
||||||
move 6 from 1 to 9
|
|
||||||
move 1 from 3 to 4
|
|
||||||
move 1 from 3 to 9
|
|
||||||
move 8 from 6 to 4
|
|
||||||
move 20 from 4 to 8
|
|
||||||
move 3 from 4 to 8
|
|
||||||
move 15 from 8 to 2
|
|
||||||
move 11 from 2 to 6
|
|
||||||
move 2 from 1 to 7
|
|
||||||
move 7 from 9 to 8
|
|
||||||
move 6 from 9 to 3
|
|
||||||
move 1 from 6 to 5
|
|
@ -1,75 +0,0 @@
|
|||||||
const std = @import("std");
|
|
||||||
|
|
||||||
const State = enum { Parse, Move };
|
|
||||||
|
|
||||||
pub fn main() !void {
|
|
||||||
var file = try std.fs.cwd().openFile("input.txt", .{});
|
|
||||||
defer file.close();
|
|
||||||
|
|
||||||
var a = std.io.bufferedReader(file.reader());
|
|
||||||
var readerStream = a.reader();
|
|
||||||
|
|
||||||
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
|
|
||||||
const allocator = gpa.allocator();
|
|
||||||
|
|
||||||
const stackCharWidth = 4;
|
|
||||||
var stackCount: ?u32 = null;
|
|
||||||
var state = State.Parse;
|
|
||||||
var stacks = std.ArrayList(std.ArrayList(u8)).init(allocator);
|
|
||||||
defer {
|
|
||||||
for (stacks.items) |stack| {
|
|
||||||
stack.deinit();
|
|
||||||
}
|
|
||||||
stacks.deinit();
|
|
||||||
}
|
|
||||||
|
|
||||||
var buf: [200]u8 = undefined;
|
|
||||||
while (try readerStream.readUntilDelimiterOrEof(&buf, '\n')) |line| {
|
|
||||||
switch (state) {
|
|
||||||
State.Parse => {
|
|
||||||
if (stackCount == null) {
|
|
||||||
// first iteration - allocate stacks
|
|
||||||
stackCount = (@intCast(u32, line.len) + 1) / stackCharWidth;
|
|
||||||
var i: u32 = 0;
|
|
||||||
while (i < stackCount.?) : (i += 1) {
|
|
||||||
try stacks.append(std.ArrayList(u8).init(allocator));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (std.mem.eql(u8, line, "")) {
|
|
||||||
// done parsing
|
|
||||||
state = State.Move;
|
|
||||||
for (stacks.items) |*stack| {
|
|
||||||
_ = stack.pop(); // the stack's index number that also gets parsed
|
|
||||||
std.mem.reverse(u8, stack.items);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// parse stacks
|
|
||||||
for (stacks.items) |*stack, i| {
|
|
||||||
const charIdx = i * stackCharWidth + 1;
|
|
||||||
const char = line[charIdx .. charIdx + 1];
|
|
||||||
if (char[0] != ' ') try stack.append(char[0]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
State.Move => {
|
|
||||||
var tokens = std.mem.split(u8, line, " ");
|
|
||||||
_ = tokens.next(); // skip "move"
|
|
||||||
const iterations = try std.fmt.parseInt(u32, tokens.next().?, 10);
|
|
||||||
_ = tokens.next(); // skip "from"
|
|
||||||
const src = try std.fmt.parseInt(u32, tokens.next().?, 10) - 1;
|
|
||||||
_ = tokens.next(); // skip "to"
|
|
||||||
const dest = try std.fmt.parseInt(u32, tokens.next().?, 10) - 1;
|
|
||||||
var i: u32 = 0;
|
|
||||||
while (i < iterations) : (i += 1) {
|
|
||||||
const tmp = stacks.items[src].pop();
|
|
||||||
try stacks.items[dest].append(tmp);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (stacks.items) |*stack| {
|
|
||||||
std.debug.print("{c}", .{stack.pop()});
|
|
||||||
}
|
|
||||||
std.debug.print("\n", .{});
|
|
||||||
}
|
|
@ -1,77 +0,0 @@
|
|||||||
const std = @import("std");
|
|
||||||
|
|
||||||
const State = enum { Parse, Move };
|
|
||||||
|
|
||||||
pub fn main() !void {
|
|
||||||
var file = try std.fs.cwd().openFile("input.txt", .{});
|
|
||||||
defer file.close();
|
|
||||||
|
|
||||||
var a = std.io.bufferedReader(file.reader());
|
|
||||||
var readerStream = a.reader();
|
|
||||||
|
|
||||||
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
|
|
||||||
const allocator = gpa.allocator();
|
|
||||||
|
|
||||||
const stackCharWidth = 4;
|
|
||||||
var stackCount: ?u32 = null;
|
|
||||||
var state = State.Parse;
|
|
||||||
var stacks = std.ArrayList(std.ArrayList(u8)).init(allocator);
|
|
||||||
defer {
|
|
||||||
for (stacks.items) |stack| {
|
|
||||||
stack.deinit();
|
|
||||||
}
|
|
||||||
stacks.deinit();
|
|
||||||
}
|
|
||||||
|
|
||||||
var buf: [200]u8 = undefined;
|
|
||||||
while (try readerStream.readUntilDelimiterOrEof(&buf, '\n')) |line| {
|
|
||||||
switch (state) {
|
|
||||||
State.Parse => {
|
|
||||||
if (stackCount == null) {
|
|
||||||
// first iteration - allocate stacks
|
|
||||||
stackCount = (@intCast(u32, line.len) + 1) / stackCharWidth;
|
|
||||||
var i: u32 = 0;
|
|
||||||
while (i < stackCount.?) : (i += 1) {
|
|
||||||
try stacks.append(std.ArrayList(u8).init(allocator));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (std.mem.eql(u8, line, "")) {
|
|
||||||
// done parsing
|
|
||||||
state = State.Move;
|
|
||||||
for (stacks.items) |*stack| {
|
|
||||||
_ = stack.pop(); // the stack's index number that also gets parsed
|
|
||||||
std.mem.reverse(u8, stack.items);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// parse stacks
|
|
||||||
for (stacks.items) |*stack, i| {
|
|
||||||
const charIdx = i * stackCharWidth + 1;
|
|
||||||
const char = line[charIdx .. charIdx + 1];
|
|
||||||
if (char[0] != ' ') try stack.append(char[0]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
State.Move => {
|
|
||||||
var tokens = std.mem.split(u8, line, " ");
|
|
||||||
_ = tokens.next(); // skip "move"
|
|
||||||
const iterations = try std.fmt.parseInt(u32, tokens.next().?, 10);
|
|
||||||
_ = tokens.next(); // skip "from"
|
|
||||||
const src = try std.fmt.parseInt(u32, tokens.next().?, 10) - 1;
|
|
||||||
_ = tokens.next(); // skip "to"
|
|
||||||
const dest = try std.fmt.parseInt(u32, tokens.next().?, 10) - 1;
|
|
||||||
var i: u32 = 0;
|
|
||||||
while (i < iterations) : (i += 1) {
|
|
||||||
const tmp = stacks.items[src].pop();
|
|
||||||
try stacks.items[dest].append(tmp);
|
|
||||||
}
|
|
||||||
const destItems = stacks.items[dest].items;
|
|
||||||
std.mem.reverse(u8, destItems[destItems.len - iterations ..]);
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (stacks.items) |*stack| {
|
|
||||||
std.debug.print("{c}", .{stack.pop()});
|
|
||||||
}
|
|
||||||
std.debug.print("\n", .{});
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user