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

Защищенный пароль

02.01.2020, 14:57. Показов 1509. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
По какому принципу формируется новый пароль?

Очень надежная и совершенно бесплатная операционная система «Vokna» известна своей безопасностью, так как при проектировании разработчики уделили большое внимание проблемам генерации паролей. Ядро операционной системы содержит в себе строку S длиной N символов. Генерация пароля происходит с использованием символов строки S. Паролем будем называть подстроку Si,j строки S длиной не менее одного и не более N символов. Подстрокой Si,j строки S называется строка, последовательно составленная из символов S[i], S[i+1], S[i+2], … , S[j-1], S[j]. Символы в строке нумеруются последовательно начиная с единицы. Пароль Si,j считается защищенным, если в нем встречается не более K одинаковых символов. Вашей задачей является по заданной строке S и числу K определить количество различных вариантов выбора защищенного пароля. Два варианта выбора пароля S1i,j и S2i',j' называются различными, если i ≠ i' или j ≠ j'.

Входные данные
Первая строка входного файла INPUT.TXT содержит два натуральных числа N (1 ≤ N ≤ 106) и K (1 ≤ K ≤ N), разделенных одиночным пробелом, где N – количество символов в строке S; K – максимальное количество одинаковых символов в пароле. Вторая строка входного файла содержит ровно N символов. Каждый символ является либо маленькой английской буквой, либо цифрой. Каждая строка входного файла заканчивается символом перевода строки.

Выходные данные
Единственная строка выходного файла OUTPUT.TXT должна содержать одно целое число – количество вариантов выбора защищенного пароля.

Пример
6 2
7aaarr 15

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
27
28
29
30
31
32
33
34
35
#include <stdio.h>
#include <iostream>
#include <cstring>
#include <vector>
  
using namespace std;
 
int main(void)
{
    freopen("input.txt", "r", stdin);   
    freopen("output.txt", "w", stdout); 
     
    int N; // N – количество символов в строке S;
    int K; // K – максимальное количество одинаковых символов в пароле
    cin >> N >> K;
    char buf[1000000+1]; //создаем массив символов на 10^6+1 элемент
    cin >> buf; //считываем из файла массив символов 
    string S(buf); //преобразование массива символов в строку S
    vector <int> count (128,0); //создаем вектор на 128 элементов и заполняем 0
    int right = -1;
    long long result = 0;
    
    for (int left=0;left<N;left++)
    {
        while(right+1<N && count[(int)S[right+1]]<K)
        {
            right++;
            count[(int)S[right]]++;
        }
        result = result + (right + 1 - left);
        count[(int)S[left]]--;
    }
    printf("%lld", result); //выводим результат
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.01.2020, 14:57
Ответы с готовыми решениями:

Запрашивать пароль до тех пор, пока правильный пароль не будет введен
Уважаемые, перепробовал кучу методов. Кто нибудь приведите пример кода программы которая запрашивает пароль (если он не верен то...

Защищенный режим DOS - С++
Нужна помощь!!! Надо написать программу на С++ для защищенного режима DOS. В проге надо записать данные в переменную до 100 мб а потом...

Заразил доки и поставил пароль а пароль забыл, не как его не взломать или не скинуть пароль с архива?
Зарарил доки и поставил пароль а пароль забыл, не как его не взломать или не скинуть пароль с архива?

6
0 / 0 / 0
Регистрация: 18.03.2019
Сообщений: 689
21.01.2020, 00:22  [ТС]
помогите, пожалуйста!
0
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
21.01.2020, 01:36
Катя6, а вы упорная. Вашу упорность бы на изучение программирования направить... Не пробовали?
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
27
28
29
30
31
32
33
34
35
36
37
38
#include <iostream>
#include <string>
#include <map>
 
using namespace std;
 
int main(void)
{
    freopen("input.txt", "r", stdin);
    freopen("output.txt", "w", stdout);
 
    size_t N; // N – количество символов в строке S;
    size_t K; // K – максимальное количество одинаковых символов в пароле
    cin >> N >> K;
    cin.ignore();
    string str, pass;
    getline(cin, str);
 
    size_t counter = 0;
    for (size_t len = 1; len < N; ++len) {
        for (size_t i = 0; i < N - len; ++i) {
            if (len < K)
                ++counter;
            else {
                pass = str.substr(i, len);
                map<char, size_t> m;
                for (size_t j = 0; j < len; ++j)
                    ++m[pass[j]];
                for (const auto &p : m)
                    if (p.second > K)
                        continue;
                ++counter;
 
            }
        }
    }
    cout << counter << endl;
}
Вроде работает. Но с пристрастием не тестировал.
0
0 / 0 / 0
Регистрация: 18.03.2019
Сообщений: 689
21.01.2020, 07:33  [ТС]
L0M, зачем мне код? у меня работает мой. Вопрос в другом же был
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
21.01.2020, 07:37
Цитата Сообщение от Катя6 Посмотреть сообщение
Вопрос в другом же был
Цитата Сообщение от Катя6 Посмотреть сообщение
По какому принципу формируется новый пароль?
Паролем будем называть подстроку Si,j строки S длиной не менее одного и не более N символов. Подстрокой Si,j строки S называется строка, последовательно составленная из символов S[i], S[i+1], S[i+2], … , S[j-1], S[j]. Символы в строке нумеруются последовательно начиная с единицы. Пароль Si,j считается защищенным, если в нем встречается не более K одинаковых символов. Вашей задачей является по заданной строке S и числу K определить количество различных вариантов выбора защищенного пароля. Два варианта выбора пароля S1i,j и S2i',j' называются различными, если i ≠ i' или j ≠ j'.

Добавлено через 1 минуту
если не понимаешь, читай, раз за разом, постепенно прозрение само придет.
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
21.01.2020, 10:01
Цитата Сообщение от Катя6 Посмотреть сообщение
По какому принципу формируется новый пароль?
По твоему примеру - нужно, чтоб пароль содержал не более двух одинаковых символов подряд, из строки 7aaarr можно сформировать 15 таких паролей.
0
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
21.01.2020, 17:37
Цитата Сообщение от Катя6 Посмотреть сообщение
зачем мне код? у меня работает мой. Вопрос в другом же был
И у вас работает код с выделением 10^6+1 байтов в стеке? Вам повезло. Если честно, я дальше этой строки ваш код не смотрел.

А по поводу вопроса... Если вы сами писали ваш код, то вы должны понимать как он работает. А написать код без понимания условий задачи обычно не получается. Что-то не сходится.

Добавлено через 1 час 28 минут
Кстати, нашёл у себя ошибочку. Вот так работает правильно:
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <iostream>
#include <string>
#include <map>
 
using namespace std;
 
int main(void)
{
    freopen("input.txt", "r", stdin);
    freopen("output.txt", "w", stdout);
 
    size_t N; // N – количество символов в строке S;
    size_t K; // K – максимальное количество одинаковых символов в пароле
    cin >> N >> K;
    cin.ignore();
    string str, pass;
    getline(cin, str);
 
    size_t counter = 0;
    bool valid = true;
    for (size_t len = 0; len < N; ++len) {
        for (size_t i = 0; i < N - len; ++i) {
            if (len < K)
                ++counter;
            else {
                pass = str.substr(i, len + 1);
                valid = true;
                map<char, size_t> m;
                for (const auto ch : pass)
                    if (++m[ch] > K) {
                        valid = false;
                        break;
                    }
                if (valid)
                    ++counter;
            }
        }
    }
    cout << counter << endl;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.01.2020, 17:37
Помогаю со студенческими работами здесь

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

Защищённый режим ОС
Надеюсь, я верно выбрал раздел на форуме :) Меня интересует такой вопрос... Каким образом приложения типа ArtMoney могут получать доступ к...

Защищённый контент
Если разработчик вставляет в приложение контент, который защищён авторскими правами, но при этом он использует его со сторонних сайтов...

защищенный режим
люди разъясните кто знает.надо переключить проц в защищенный режим работы. часть кода code segment ...... db 0eah ;(1)машинный...

защищенный режим
а как можно изменить длину сегмента (предел) и потом снова считать его? Написать процедуру, меняющую в защищенном режиме предел ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru