Răspuns :
PROBLEMA 1
#include <iostream>
using namespace std;
class data_calendaristica {
private:
unsigned zi, luna, an;
bool este_an_bisect() {
if (an % 400 == 0)return 1;
if (an % 100 == 0)return 0;
if (an % 4 == 0)return 1;
return 0;
}
public:
void seteaza_data(unsigned z, unsigned l, unsigned a) {
an = a;
luna = l;
zi = z;
}
void maine() {
zi++;
//Overflow luna
if ((luna == 1 || luna == 3 || luna == 5 || luna == 7 || luna == 8 || luna == 10 || luna == 12) && zi == 32) {
zi = 1;
luna += 1;
}
else if ((luna == 4 || luna == 6 || luna == 9 || luna == 11) && zi == 31) {
zi = 1;
luna += 1;
}
else if (luna == 2) {
if (zi == 29 && !este_an_bisect() || zi==30 && este_an_bisect()) {
zi = 1;
luna++;
}
}
//Overflow an
if (luna == 13) {
luna = 1;
an++;
este_an_bisect();
}
}
void afisare_data() {
cout << "Data : " << zi << " " << luna << " " << an << endl;
}
};
int main(){
unsigned z, l, a;
cout << "Introduceti ziua, luna si anul : ";
cin >> z >> l >> a;
data_calendaristica x;
x.seteaza_data(z, l, a);
cout << "Azi : ";
x.afisare_data();
x.maine();
cout << "Maine : ";
x.afisare_data();
}
PROBLEMA 2
#include <iostream>
#include <math.h>
using namespace std;
class ecuatie_grad_2 {
private:
float a, b, c;
float delta;
public:
void initializeaza(float temp_a, float temp_b, float temp_c) {
a = temp_a;
b = temp_b;
c = temp_c;
}
float calc_delta() {
return b * b - 4 * a * c;
}
void afisare_solutie() {
cout << endl;
if (delta < 0) cout << "Ecuatia nu are solutii reale";
else if (delta == 0)cout << "Ecuatia are solutia x = " << -b / (2 * a);
else cout << "Ecuatia are solutiile x1 = " << (-b + sqrt(delta)) / (2 * a) << " si x2 = " << (-b - sqrt(delta)) / (2 * a);
cout << endl;
}
ecuatie_grad_2(float temp_a, float temp_b, float temp_c) {
initializeaza(temp_a, temp_b, temp_c);
delta = calc_delta();
afisare_solutie();
}
};
class ecuatie_grad_1 {
private:
float a, b;
public:
void initializeaza(float temp_a, float temp_b) {
a = temp_a;
b = temp_b;
}
void afisare_solutie() {
cout << endl;
if (a == 0 && b == 0) cout << "Ecuatia are o infinitate de solutii";
else if (a == 0) cout << "Ecuatia nu are solutii";
else cout << "Solutia ecuatiei este x = " << -b / a;
cout << endl;
}
ecuatie_grad_1(float temp_a, float temp_b) {
initializeaza(temp_a, temp_b);
afisare_solutie();
}
};
int main(){
int a, b, c;
cout << "Introduceti coeficientii ecuatiei de grad 2 : ";
cin >> a >> b >> c;
ecuatie_grad_2(a, b, c);
cout << "Introduceti coeficientii ecuatiei de grad 1 : ";
cin >> a >> b;
ecuatie_grad_1(a, b);
}