pvjc24/a1/program.c
Bohdan Kapliuk 05049d7373 a1
2024-03-28 22:49:19 +02:00

73 lines
1.7 KiB
C

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <stdbool.h>
#define SIZE 100
bool checkZnaka(char znaky[],char znak1){
for(int i = 0;i < 4;i++){
if(znaky[i] == znak1){
return false;
}
}
return true;
}
struct vzorec{
double x;
double y;
double result;
char znak1;
char znak2;
};
int main(){
int results[SIZE];
char line[SIZE];
char znaky[] = "+-*/";
memset(line,0,SIZE);
struct vzorec funkcia[SIZE];
memset(funkcia,0,SIZE);
char* pEnd;
int counter = 0;
while (fgets(line,SIZE,stdin) && line[0] != '\n'){
if(line == NULL){
break;
}
int n = sscanf(line, "%lf %c %lf %c %lf", &funkcia->x, &funkcia->znak1, &funkcia->y, &funkcia->znak2, &funkcia->result);
if(checkZnaka(znaky, funkcia->znak1) == true || funkcia->znak2 != '='){
results[counter] = 1;
counter++;
continue;
}
double r1 = (round(funkcia->x*100) + round(funkcia->y*100))/100;
double r2 = (round(funkcia->x*100) - round(funkcia->y*100))/100;
double r3 = (round(funkcia->x*100) * round(funkcia->y))/100;
double r4 = (round(funkcia->x*100) / round(funkcia->y))/100;
if(funkcia->result != r1 && funkcia->result != r2 && funkcia->result != r3 && funkcia->result != r4){
results[counter] = 2;
counter++;
continue;
}
else{
results[counter] = 3;
counter++;
continue;
}
}
for(int i = 0; i <= counter;i++){
if(results[i] == 1){
printf("CHYBA\n");
}
if(results[i] == 2){
printf("ZLE\n");
}
if(results[i] == 3){
printf("OK\n");
}
}
return 0;
}