#include <iostream>
#include <sstream>
#include <string>
using namespace std;
class Rectangle
{
private:
int a = 0, b = 0;
string rectInSrt;
public:
Rectangle()
{
a = 0; b = 0;
}
int operator[] (int i)
{
if (i == 0) return a;
else if (i == 1) return b;
else cout << "Boundary Error\n";
exit(1);
}
Rectangle& operator++ ()
{
a += 1;
b += 1;
return *this;
}
Rectangle operator++ (int)
{
Rectangle prev = *this;
++*this;
return prev;
}
Rectangle& operator-- ()
{
a -= 1;
b -= 1;
return *this;
}
Rectangle operator-- (int)
{
Rectangle prev = *this;
--*this;
return prev;
}
operator bool() const
{
return (a == b);
}
Rectangle operator*= (int c)
{
a *= c;
b *= c;
return *this;
}
operator string() const
{
stringstream ss;
ss << a << ' ' << b;
string rectInSrt = ss.str();
return rectInSrt;
}
string operator=(string s)
{
stringstream ss;
ss << s;
ss >> a >> b;
string rectInSrt = ss.str();
return rectInSrt;
}
};
int main()
{
Rectangle rect;
++rect;
rect *= 5;
cout << rect[0] << ' ' << rect[1] << ' ' << (rect == true) << endl;
string s;
s = rect;
cout << s << endl;
s = "2 3";
rect = s;
cout << rect[0] << ' ' << rect[1] << ' ' << (rect == true) << endl;
system("pause");
return 0;
}
Решил все же сделать, вспомнить, как это устроеноXD Не уверен, что все сделал как надо, но вроде работает. Ты хотя бы в коде разберись, перегрузка штука полезная.
875*8=35*а*4 ⇒ а=875*8/(35*4) ⇒ а=50 пикселей
В неделе семь дней, поэтому решение выполняется на основе нахождения остатка целочисленного деления от номера дня на 7. Такой остаток находится в пределах от 0 до 6, а для нашей нумерации нужны значения от 1 до 7, поэтому полученный остаток будем увеличивать на единицу. Если 1 января вторник, то есть день недели с номером 2, то первым понедельником будет 7 января, вторым 14 января и т.д. 1 января (k=1) при делении на 7 даст в остатке 1 и при сдвиге остатка на 1 (см. выше), получим 2 (вторник). 7 января даст остаток 0 и после сдвига получим 1 (понедельник), что и требовалось.
<u>1. Современное короткое, эффективное, но требующее определенных знаний решение</u>
<u>PascalABC.NET 3.3.5, сборка 1659 от 09.04.2018</u>
<u>Внимание! Если программа не работает, обновите версию!</u>
begin
var d:='Понедельник Вторник Среда Четверг Пятница Суббота Воскресенье'.ToWords;
Writeln(d[ReadInteger('Введите номер дня') mod 7])
end.
<u>Примеры</u>
Введите номер дня 215
Суббота
Введите номер дня 14
Понедельник
<u>2. Более близкое к приведенному выше алгоритму решение</u>
begin
var n:=ReadInteger('Введите номер дня');
n:=n mod 7+1;
case n of
0:Writeln('Воскресенье');
1:Writeln('Понедельник');
2:Writeln('Вторник');
3:Writeln('Среда');
4:Writeln('Четверг');
5:Writeln('Пятница');
6:Writeln('Суббота')
end
end.
<u>3. Типовое школьное решение</u>
var
n:integer;
begin
Write('Введите номер дня');
Read(n);
n:=n mod 7+1;
case n of
0:Writeln('Воскресенье');
1:Writeln('Понедельник');
2:Writeln('Вторник');
3:Writeln('Среда');
4:Writeln('Четверг');
5:Writeln('Пятница');
6:Writeln('Суббота')
end
end.
Здесь надо посчитать в процентах но вот есть сомнения а или б если я угадаю одну из шапок там будут все синие то есть 50%
а там вероятность того что выпадет меньше
Правильный вариант Б)
Const n = 20;
var a:array[1..n] of integer;
i:integer;
begin
for i:=1 to n do
readln(a[i]);
for i:=1 to n do
if (a[i] mod 3 = 0) and (a[i] mod 5=0) then
Writeln('elem nomer ' , i)
<span>end.</span>