Fixed function
This commit is contained in:
parent
893de2c1dc
commit
3d63bd9c11
|
@ -7,61 +7,48 @@ typedef struct {
|
||||||
float juice, alcohool;
|
float juice, alcohool;
|
||||||
} Barrel;
|
} Barrel;
|
||||||
|
|
||||||
bool readInput(Barrel * line[2], Barrel * reservoir) {
|
int balancear() {
|
||||||
int i;
|
int i, result;
|
||||||
float f;
|
float f, capacity;
|
||||||
|
Barrel line[2], sortedLine[2], * finalLine, reservoir;
|
||||||
|
|
||||||
|
/* Read Input */
|
||||||
for (i = 0; i < 4; i++) {
|
for (i = 0; i < 4; i++) {
|
||||||
if (!scanf(" %f", &f) || f <= 0)
|
if (!scanf(" %f", &f) || f <= 0)
|
||||||
return false;
|
return EOF;
|
||||||
if (i % 2 == 0) {
|
if (i % 2 == 0) {
|
||||||
line[i / 2]->no = i / 2 + 1;
|
line[i / 2].no = i / 2 + 1;
|
||||||
line[i / 2]->juice = f;
|
line[i / 2].juice = f;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (f > 1)
|
if (f > 1)
|
||||||
return false;
|
return EOF;
|
||||||
line[i / 2]->alcohool = f * line[i / 2]->juice;
|
line[i / 2].alcohool = f * line[i / 2].juice;
|
||||||
line[i / 2]->juice -= line[i / 2]->alcohool;
|
line[i / 2].juice -= line[i / 2].alcohool;
|
||||||
}
|
}
|
||||||
reservoir->juice = line[0]->juice + line[1]->juice;
|
reservoir.juice = line[0].juice + line[1].juice;
|
||||||
reservoir->alcohool = line[0]->alcohool + line[1]->alcohool;
|
reservoir.alcohool = line[0].alcohool + line[1].alcohool;
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
Barrel * sortLine(Barrel * line) {
|
/* Sort Line */
|
||||||
if (line[0].juice + line[0].alcohool > line[1].juice + line[1].alcohool)
|
if (line[0].juice + line[0].alcohool < line[1].juice + line[1].alcohool) {
|
||||||
return line;
|
sortedLine[0] = line[1];
|
||||||
|
sortedLine[1] = line[0];
|
||||||
Barrel * sortedLine[2];
|
finalLine = sortedLine;
|
||||||
*sortedLine[0] = *line[1];
|
|
||||||
*sortedLine[1] = *line[0];
|
|
||||||
return sortedLine;
|
|
||||||
}
|
|
||||||
|
|
||||||
int loadBarrel (Barrel * reservoir, Barrel barrel) {
|
|
||||||
float capacity = barrel.juice + barrel.alcohool;
|
|
||||||
if (reservoir->juice - capacity * 0.86 >= 0 &&
|
|
||||||
reservoir->alcohool - capacity * 0.14 >= 0) {
|
|
||||||
reservoir->juice -= capacity * 0.86;
|
|
||||||
reservoir->alcohool -= capacity * 0.14;
|
|
||||||
return barrel.no;
|
|
||||||
}
|
}
|
||||||
return 0;
|
else
|
||||||
}
|
finalLine = line;
|
||||||
|
|
||||||
int balancear() {
|
/* Load Barrels */
|
||||||
int i, result;
|
for (i = 0; i < 2; i++) {
|
||||||
Barrel line[2], reservoir;
|
capacity = finalLine[i].juice + finalLine[i].alcohool;
|
||||||
|
if (reservoir.juice - capacity * 0.86 >= 0 &&
|
||||||
if (!readInput(&line, &reservoir))
|
reservoir.alcohool - capacity * 0.14 >= 0) {
|
||||||
return EOF;
|
reservoir.juice -= capacity * 0.86;
|
||||||
|
reservoir.alcohool -= capacity * 0.14;
|
||||||
line = sortLine(line);
|
result += finalLine[i].no;
|
||||||
|
}
|
||||||
for (i = 0; i < 2; i++)
|
}
|
||||||
result += loadBarrel(&reservoir, line[i]);
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue