Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 27.05.2019
Сообщений: 4

Посчитать количество символов, которые нужно заменить, чтобы в ней были только уникальные буквы английского алфавита

29.05.2019, 19:57. Показов 2420. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В первой строке входных данных записано целое число n (1 ≤ n ≤ 100 000) — длина строки s.
Во второй строке записана строка s длины n, состоящая из строчных букв английского алфавита.
Если невозможно изменить строку s так, чтобы все её подстроки были различны, то выведите -1.
Пример:
Вход: 5 kokoj
Выход: 2

Попробовал реализовать через сортировку char-массива, содержащий буквы строки и определение количества идущих подряд букв. Но выдаёт ошибку на 30-ом тесте. Мне не нужно сейчас оптимальное решение, мне требуется знать, в чём состоит ошибка.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include <bits/stdc++.h>
using namespace std;
int main()
 
{
 
int n, quantity=0, j=0; //quantity - количество букв, которое надо изменить, j - счётчик для цикла while
cin>>n;
string s;
cin>>s;
char a [n];
for (int i=0; i<n; i++)
    a [i] = s [i];
sort (a, a + n);
while (j < n)
{
    quantity += quantity + count (a, a+n, a[j]) - 1;
    j += count (a, a+n, a[j]);
}
 
if (26 - quantity < 1) //если английского алфавита не хватает, то изменить строку нельзя
    cout<<-1;
else
    cout<<quantity;
 
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.05.2019, 19:57
Ответы с готовыми решениями:

Ввести строку символов и заменить большие буквы английского алфавита в диапазоне от ‘G’ до ‘V’ на маленькие
Помогите выполнить задание: Ввести строку символов и заменить большие буквы английского алфавита в диапазоне от ‘G’ до ‘V’ на маленькие....

Превратить строку так, чтобы сначала в ней были напечатаны только буквы, а потом только цифры
Превратить строку так, чтобы сначала в ней были напечатаны только буквы, а потом только цифры, не меняя порядка прохождения символов в...

Преобразовать строку таким образом, чтобы сначала в ней были напечатаны только буквы, а потом только цифры
Задана строка, состоящая из символов. Символы объединяются в слова. Слова друг от друга отделяются одним или несколькими пробелами. В конце...

4
 Аватар для 7533620
163 / 70 / 39
Регистрация: 28.05.2019
Сообщений: 241
29.05.2019, 20:04
Цитата Сообщение от Korostast Посмотреть сообщение
изменить строку s так
Изменить как?
0
0 / 0 / 0
Регистрация: 27.05.2019
Сообщений: 4
29.05.2019, 20:07  [ТС]
Неправильно условие подал: нужно только посчитать количество букв, которые нужно заменить, чтобы в строке не повторялись буквы (а если алфавита не хватает, чтобы все буквы были уникальными, то вывести -1)
0
 Аватар для 7533620
163 / 70 / 39
Регистрация: 28.05.2019
Сообщений: 241
29.05.2019, 20:18
Так что ли?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
int main()
{
    string s;
    getline(cin, s);
 
    if (s.size() > 26)
    {
        cout << -1 << endl;
        return 0;
    }
 
    vector<int> q(26, 0);
    for (auto c : s)
        ++q[c - 'a'];
 
    int ans = 0;
    for (auto e : q)
        if (e > 1)
            ans += e - 1;
    cout << ans << endl;
 
    return 0;
}
1
0 / 0 / 0
Регистрация: 27.05.2019
Сообщений: 4
29.05.2019, 20:24  [ТС]
Да, данное решение верное
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.05.2019, 20:24
Помогаю со студенческими работами здесь

Нужно вывести все буквы, которые встречаются в ней , и их количество , легкий код только сделайте плз
Пример Input zazbazy output a 2 ...

Обработать строку так, чтобы чтобы в ней остались только те слова которые содержат буквы и цифры
Привет всем, помогите решить задачу. Обработать строку таким образом чтобы чтобы в ней остались только те слова которые содержат буквы и...

Ввести строку символов, посчитать количество символов, не являющихся буквами английского алфавита
Ввести строку символов, если ее длина &gt;6, то посчитать количество символов, не являющихся буквами английского алфавита. Полученное значение...

Заменить все строчные согласные буквы английского алфавита на заглавные
помогите с решением задачи. Запросить у пользователя ввод строки. Выполнить задание согласно варианту и вывести результирующую строку....

Объявить два диапазонных типа: один буквы русского алфавита, второй буквы английского алфавита
Объявить два диапазонных типа: один буквы русского алфавита, второй буквы английского алфавита. Вводится буква с клавиатуры - выводится к...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru