/*
* Copyright (C) 2022 Camden Dixie O'Brien
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public
* License along with this program. If not, see
* .
*/
#include "ds.h"
#include "sud.h"
#include
#include
#include
#define RESNAME "results"
#define SOLNAME "solns"
int main(void)
{
FILE *rfp = fopen(RESNAME, "rb");
if (!rfp) {
fputs("Failed to open results file\n", stderr);
return EXIT_FAILURE;
}
FILE *sfp = fopen(SOLNAME, "rb");
if (!sfp) {
fputs("Failed to open solutions file\n", stderr);
return EXIT_FAILURE;
}
unsigned correct = 0;
char res[NCELLS], sol[NCELLS];
for (unsigned i = 0; i < NPUZZ; ++i) {
if (fread(&res, sizeof(char), NCELLS, rfp) != NCELLS) {
fprintf(stderr, "Failed to read result #%u\n", i);
return EXIT_FAILURE;
}
if (fread(&sol, sizeof(char), NCELLS, sfp) != NCELLS) {
fprintf(stderr, "Failed to read result #%u\n", i);
return EXIT_FAILURE;
}
if (memcmp(res, sol, NCELLS) == 0)
++correct;
}
double pc = 1e2 * (double)correct / (double)NPUZZ;
printf("%u/%u correct (%.2f%%)\n", correct, NPUZZ, pc);
fclose(rfp);
fclose(sfp);
return EXIT_SUCCESS;
}