Автор некоторого документа ввёл заголовок текста, в котором символы отделил пробелами для увеличения расстояния между ними. Правильно ли он сделал? Что вы ему посоветуете?
1):С:\Учебный\Информатика\Кодирование -> С:\Учебный\Информатика -> С:\Учебный -> С:\Учебный\Информатика -> С:\Учебный\Информатика\Кодирование -> С:\Учебный\Информатика -> С:\Учебный -> Не подходит, т.к. Витя опустился на n уровней, а поднялся на n+2, что не подходит по условию. 2)С:\Учебный\Информатика\Кодирование -> С:\Учебный\Информатика -> С:\Учебный -> С:\Учебный\Информатика -> С:\Учебный\Информатика\Программирование-> С:\Учебный\Информатика\Программирование\Паскаль Не подходит, т.к. Витя спустился на либо на 2 уровня вниз, либо на 3, а поднялся либо на 3, либо на 4 уровня вверх, что не подходит по условию. 3)С:\Учебный\Информатика\Кодирование -> С:\Учебный\Информатика -> С:\Учебный -> С:\Учебный\Математика -> С:\Учебный\Математика\Дроби Подходит. Витя опустился на 2 уровня вниз и поднялся на 2 уровня вверх. 4)С:\Учебный\Информатика\Кодирование -> С:\Учебный\Информатика -> С:\Учебный -> С:\ -> С:\Учебный\ -> С:\Учебный\Информатика Не подходит, т.к. Витя спустился на 3 уровня вниз, а поднялся на 2, что не подходит по условию. ответ: 3)
// В данном примере я использовал типы float, т. к. при попытке делить 3 на 2 мы получаем 1.5, но тип int обрезает все после .
int main()
{
cout << "Task 30240725!" << endl; // just for fun
int m[12] = {-1,-2,3,4,5,6,7,8,9,10,11,12}; // Инициализируем массив из 12 элементов, чтоб хоть части из них была отрицательная
// среднее арифметическое состоит из сумма_числел / кол-во_чисел
float min_sum = 0; // сумма чисел
float total_min_count = 0; // кол-во чисел
// Инициализиуем цикл от 0 (т. к. все массивы начинаются с 0) до 12 не включительно (т. к. всего элементов 12 начиная с 0. Значит 11)
for (int i = 0; i < 12; i++) {
// если текущий элемент массива m от индекса i меньше чем 0, значит это отрицательное число
if (m[i] < 0) {
min_sum += m[i]; // складываем, непосредственно, само число m[i]
total_min_count++; // увеличиваем кол-во чисел на 1. Можно написать строку вида total_min_count = total_min_count + 1; - суть не поменяется
}
}
// Если в массиве не было отрицательных чисел, то делаем проверку. Если кол_во_чисел и сумма_чисел равны 0 значит в массиве не было отрицательных чисел.
// а т. к. по умолчанию min_sum и total_min_count равны 0, то при попытке поделить их получим ошибку. Для этого обрабатываем это условие, чтоб не дать ее допустить.
if (total_min_count == 0 && min_sum == 0) {
// Выкидываем сообщение, мол, нету в массиве отрицательных чисел, работать не буду
cout << "There are no negative numbers in the array" << endl;
// делаем return, дабы программа не продолжила выполнение
return 0;
}
// если же у нас есть и кол-во_чисел и общая_сумма, то спокойно делим одно на другое и сразу выводим в консоль результат.
С:\Учебный\Информатика ->
С:\Учебный ->
С:\Учебный\Информатика ->
С:\Учебный\Информатика\Кодирование ->
С:\Учебный\Информатика ->
С:\Учебный ->
Не подходит, т.к. Витя опустился на n уровней, а поднялся на n+2, что не подходит по условию.
2)С:\Учебный\Информатика\Кодирование ->
С:\Учебный\Информатика ->
С:\Учебный ->
С:\Учебный\Информатика ->
С:\Учебный\Информатика\Программирование->
С:\Учебный\Информатика\Программирование\Паскаль
Не подходит, т.к. Витя спустился на либо на 2 уровня вниз, либо на 3, а поднялся либо на 3, либо на 4 уровня вверх, что не подходит по условию.
3)С:\Учебный\Информатика\Кодирование ->
С:\Учебный\Информатика ->
С:\Учебный ->
С:\Учебный\Математика ->
С:\Учебный\Математика\Дроби
Подходит. Витя опустился на 2 уровня вниз и поднялся на 2 уровня вверх.
4)С:\Учебный\Информатика\Кодирование ->
С:\Учебный\Информатика ->
С:\Учебный ->
С:\ ->
С:\Учебный\ ->
С:\Учебный\Информатика
Не подходит, т.к. Витя спустился на 3 уровня вниз, а поднялся на 2, что не подходит по условию.
ответ: 3)
Как-то так:
#include <iostream>
using namespace std;
// В данном примере я использовал типы float, т. к. при попытке делить 3 на 2 мы получаем 1.5, но тип int обрезает все после .
int main()
{
cout << "Task 30240725!" << endl; // just for fun
int m[12] = {-1,-2,3,4,5,6,7,8,9,10,11,12}; // Инициализируем массив из 12 элементов, чтоб хоть части из них была отрицательная
// среднее арифметическое состоит из сумма_числел / кол-во_чисел
float min_sum = 0; // сумма чисел
float total_min_count = 0; // кол-во чисел
// Инициализиуем цикл от 0 (т. к. все массивы начинаются с 0) до 12 не включительно (т. к. всего элементов 12 начиная с 0. Значит 11)
for (int i = 0; i < 12; i++) {
// если текущий элемент массива m от индекса i меньше чем 0, значит это отрицательное число
if (m[i] < 0) {
min_sum += m[i]; // складываем, непосредственно, само число m[i]
total_min_count++; // увеличиваем кол-во чисел на 1. Можно написать строку вида total_min_count = total_min_count + 1; - суть не поменяется
}
}
// Если в массиве не было отрицательных чисел, то делаем проверку. Если кол_во_чисел и сумма_чисел равны 0 значит в массиве не было отрицательных чисел.
// а т. к. по умолчанию min_sum и total_min_count равны 0, то при попытке поделить их получим ошибку. Для этого обрабатываем это условие, чтоб не дать ее допустить.
if (total_min_count == 0 && min_sum == 0) {
// Выкидываем сообщение, мол, нету в массиве отрицательных чисел, работать не буду
cout << "There are no negative numbers in the array" << endl;
// делаем return, дабы программа не продолжила выполнение
return 0;
}
// если же у нас есть и кол-во_чисел и общая_сумма, то спокойно делим одно на другое и сразу выводим в консоль результат.
cout << "Average: " << min_sum / total_min_count << endl;
// завершаем выполнение программы
return 0;
}