Условие пытается немного обмануть решающего. На самом деле всегда можно выбрать Рахманов ломтик строки, состоящий из одного символа (действительно, если в искомой подстроке несколько символов, то каждый из них встречается не меньшее число раз, что и сама подстрока). В итоге задача превращается в тривиальную: считать строку и вывести символ, встречающийся максимальное число раз.
#include <iostream>
#include <math.h> // для функции sqrt()
using namespace std;
int main()
{
setlocale(LC_ALL, "Russian");
int x;
cout << "Введите x: ";
cin >> x;
if((x + 5) < 0){
cout << "Корень из отрицательного числа не вычисляется!" << endl;
return 0;
}
else {
cout << "Корень из " << x + 5 << " равен " << sqrt(x + 5) << endl;
}
return 0;
}
Проверка:
Введите x: 139
Корень из 144 равен 12
Введите x: -5
Корень из 0 равен 0
Введите x: -6
Корень из отрицательного числа не вычисляется!
Условие пытается немного обмануть решающего. На самом деле всегда можно выбрать Рахманов ломтик строки, состоящий из одного символа (действительно, если в искомой подстроке несколько символов, то каждый из них встречается не меньшее число раз, что и сама подстрока). В итоге задача превращается в тривиальную: считать строку и вывести символ, встречающийся максимальное число раз.
#include <iostream>
int main() {
char c, maxchar;
int count[26] = {0}, maxcount = 0;
while (std::cin.get(c)) {
count[c - 'a']++;
}
for (c = 0; c < 26; c++) {
if (count[c] > maxcount) {
maxcount = count[c];
maxchar = c;
}
}
std::cout << static_cast<char>(maxchar + 'a');
return 0;
}
Подробнее - на -