Предмет: Математика, автор: zaharaazv

Помогите решить в столбик
2747:41
3796:52
8918:91
7544:82​

Ответы

Автор ответа: edhdu730
1
!!!!!!!!!!!!!!!!!!!!!!!!!!
Приложения:

zaharaazv: спасибо очень благодарен
zaharaazv: только там 67
zaharaazv: а не 6
edhdu730: изивни
edhdu730: извини**
zaharaazv: нечего с кем не бывает
zaharaazv: нечего с кем не бывает
Автор ответа: aiganymmd
1
1) 2747|41
2747|67
_______
0(ответ:67)


2)3796|52
3796|73
_______
0(ответ:73)


3)8918|91
8918|98
______
0(ответ:98)


4)7544|82
7544|92
_______
0(ответ:92)

zaharaazv: спасибо
Похожие вопросы
Предмет: Информатика, автор: Kukuwka0Ha0DepeBe
С++
Добавить к коду следующие:
ДВУСВЯЗНЫЙ список
1. Есть указатель на последнюю ячейку (tail).
2. Каждая ячейка знает где находится прошлая.
Код:
#include
#include
using namespace std;


// Одна ячейка односвязного списка
// В структуре всё по-умолчанию public

// T - шаблон. Позволяет создавать объекты, указывая тип данных T
template
struct Node {

T value; // значение ячейки
Node* pNext; // указатель на следующую ячейку

Node(T value = T()) {
this->value = value;
this->pNext = nullptr;
}
};



// Односвязный список
template
class ForwardList {

// Node будет заменяться на Node
typedef Node Node;

Node* head; // указатель на первую ячейку
unsigned int size; // кол-во ячеек (unsigned int - инты без минуса)

public:

ForwardList() {

head = nullptr; // head = 00000000
size = 0;
}

unsigned int GetSize() const {

return size;
}

void PushFront(const T value) {

size++;

// Если список пуст
if (head == nullptr) {

// Создаю новую ячейку и привязываю её к указателю на первую ячейку
head = new Node(value);
// окончить функцию (дальше не сработет)
return;
}

// Если список не был пуст

// Создаю новую ячейку, которая станет первой
Node* temp = new Node(value);

// Следующей от темп будет нынешняя первая ячейка
temp->pNext = head;

// Переключую указатель на первую ячейку на новосозданную
head = temp;
}

void PopFront() {

if (head == nullptr)
return;

// Сохраняем адрес второй ячейки
Node* temp = head->pNext;

// удаляем первую ячейку
delete head;

// переключаем голову на вторую (теперь первую) ячейку
head = temp;

size--;
}

// !!! НЕОПТИМИЗИРОВАННО ИЗ-ЗА СПЕЦИФИКИ ОДНОСВЯЗНОГО СПИСКА
void PushBack(const T value) {

size++;

if (head == nullptr) {
head = new Node(value);
return;
}

// Создаю указатель для перебора ячеек
Node* temp = head;

// Переключаю указатель на последнюю ячейку
while (temp->pNext != nullptr)
temp = temp->pNext;

// Создаю новую ячейку после последней
temp->pNext = new Node(value);
}

// Вывод односвязного списка на экран
void Print() const {

// Создаем указатель для перебора ячеек
// Сначала он будет указывать на первую ячейку
Node* temp = head;

// Перебираем ячейки до тех пор пока не вылезем за пределы
while (temp != nullptr) {

// Вывожу значение ячейки на экран
std::cout << temp->value << " ";

// Переключаю указатель на следующую ячейку
temp = temp->pNext;
}
std::cout << std::endl;
}


bool operator ==(const ForwardList & other) const {

if (this->size != other.size)
return false;

// Указатель для перебора this листа
Node* thisTemp = this->head;
// указатель для перебора other листа
Node* otherTemp = other.head;

// перебираем пока не переберём весь лист
while (thisTemp != nullptr) {

// Если пара ячеек не совпала по значению - списки не равны
if (thisTemp->value != otherTemp->value)
return false;

thisTemp = thisTemp->pNext;
otherTemp = otherTemp->pNext;
}

// Если до сюда ни разу не сработал return false - значит все ок и списки равны
return true;
}
};


int main() {

// DZ
// 1. PopBack (удаление с конца)
// 2. Insert (добавление по индексу)
// 3. RemoveAt (удаление по индексу)
// 4. operator +
// 5. Конструктор копирования
// 6. Сортировка
// 7. GetUnique, который возвращает новый лист ТОЛЬКО из уникальных элементов

ForwardList fl;
fl.PushBack(1);
fl.PushBack(2);
fl.PushBack(3);

ForwardList fl2;
fl2.PushBack(1);
fl2.PushBack(2);
fl2.PushBack(3);

if (fl == fl2)
std::cout << "LISTS ARE EQUAL" << std::endl;

}
Предмет: Алгебра, автор: v20091
Заполните пропуски(*) так, чтобы получилось верное решение(если можно на сириусе).
Задача. В 10 одинаковых бочонков разлит квас, причём общий объём кваса меньше объёма одного бочонка. За одну операцию можно выбрать бочонок и отлить из него любое количество кваса поровну в остальные бочонки. Необходимо получить одинаковые объёмы кваса во всех бочонках.

Решение. Будем последовательно уравнивать объёмы кваса в бочонках.

Шаг 1. Рассмотрим два бочонка с *(наименьшим/наибольшим) содержанием кваса. Отольём квас из *(меньшего/большего) из этих двух по всем девяти остальным так, чтобы в двух рассматриваемых бочонках количество кваса уравнялось.

Шаг 2. Теперь рассмотрим три бочонка с *(наименьшим/наибольшим) содержанием кваса. Среди них уже два *(наименьших/наибольших) содержат поровну кваса. Отольём квас из *(меньшего/большего) из этих трёх по всем девяти остальным так, чтобы в трёх рассматриваемых бочонках количество кваса уравнялось.

И так далее. Дадим описание процесса на шаге с номером k.

Шаг k. Рассмотрим *(k-1/k/k+1) бочонков с *(наименьшим/наибольшим) содержанием кваса. По построению процесса среди них уже *(k-1/k/k+1)*(наименьших/наибольших) содержат поровну кваса. Отольём квас из

*(меньшего/большего) из рассматриваемых бочонков по всем девяти остальным так, чтобы в рассматриваемых бочонках количество кваса уравнялось.

После шага с номером *(9/10/11) мы уравняем количество кваса во всех десяти бочонках, то есть суммарное число затраченных операций не превосходит *(9/10/11).