Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,922 questions

51,855 answers

573 users

How to print the number of substrings with exactly k distinct characters in C++

1 Answer

0 votes
#include <string>
#include <vector>
#include <set>
#include <iostream>

void PrintSubstringWithKDistinctChars(const std::string &s, int k) {
	std::vector<std::string> substring;
	int size = s.length();

	for (int i = 0; i < size; i++) {
		char ch = s[i];
		std::string tmp = "";
		tmp += ch;
		std::set<char> st;
		st.insert(ch);

		for (int j = i + 1; j < size; j++) {
			char next_ch = s[j];
			st.insert(next_ch);
			tmp += next_ch;
			
			if (tmp.length() >= k && st.size() == k) {
				substring.push_back(tmp);
			}
		}
	}

	for (auto const &sub: substring) {
        std::cout << sub << " ";
    }
}

int main()
{
	std::string str = "characters";
	int k = 4;

	PrintSubstringWithKDistinctChars(str, k);
}




/*
run:

char chara charac harac aract ract acte cter ters 

*/

 



answered Sep 18, 2022 by avibootz
...