• 0

How to compare 1 string against multiple strings?


Question

Ok, I am a beginner at c++ and I cannot figure out the best way to compare a string to multiple strings....

Basically I want something to do this:

1. User enters name such as John Doe, but I want it to not matter if they type it in uppercase, lowercase, etc.

2. Name is checked against multiple strings such as...(john doe) (John Doe) (JOHN DOE)

3. if the name the user enters matches one of those the result is 0, or something similar.

What is the best way to do this? Is there a way that I could just type one string to compare it to the name the user enters instead of every possibility? So I need a way to compare it disregarding the uppercase, lowercase....I think.

Thanks for any help!

Also, I can never think of any programs to make for practice, is there a website with some ideas?

17 answers to this question

Recommended Posts

  • 0
  PricklyPoo said:
Ok, I am a beginner at c++ and I cannot figure out the best way to compare a string to multiple strings....

Basically I want something to do this:

1. User enters name such as John Doe, but I want it to not matter if they type it in uppercase, lowercase, etc.

2. Name is checked against multiple strings such as...(john doe) (John Doe) (JOHN DOE)

3. if the name the user enters matches one of those the result is 0, or something similar.

What is the best way to do this? Is there a way that I could just type one string to compare it to the name the user enters instead of every possibility? So I need a way to compare it disregarding the uppercase, lowercase....I think.

Thanks for any help!

Also, I can never think of any programs to make for practice, is there a website with some ideas?

Take the string and change it to all upper or all lower then compare once.

  • 0
  PricklyPoo said:
But what happens if the user enters JoHn dOE....

You take the string "JoHn dOE" convert to all upper = "JOHN DOE" then comare. If all you want to do is verify that john doe was typed regardless of case then change the case of the string and compare to match. If you have to compare against a certain case (John Doe is different then john doe) then you need multiple compares.

  • 0

It doesn't matter. It changes the entire string to upper case. If you do that, like a8ball said, you can just compare 1 time instead of doing it multiple times.

  • 0
  a8ball said:
You take the string "JoHn dOE" convert to all upper = "JOHN DOE" then comare. If all you want to do is verify that john doe was typed regardless of case then change the case of the string and compare to match. If you have to compare against a certain case (John Doe is different then john doe) then you need multiple compares.
  IceBreakerG said:
It doesn't matter. It changes the entire string to upper case. If you do that, like a8ball said, you can just compare 1 time instead of doing it multiple times.

Oh, I see now, thanks!

  • 0

I just tried to make a quick program but I must be doing a lot wrong since I am getting errors, please help! :p

#include<iostream>
#include <cctype>
#include<string>
using namespace std;

int main()
{

	char johndoe[] = "john doe";
	char name[50];

	cout << "Please Enter Your First And Last Name.\n" << endl;

	cin.getline(name, 50, '\n');

	name=tolower(name);

   if (strcmp(johndoe, name) = 0 ){

	cout << "You Are John Doe.\n";
	}
	else {
		 cout << "You Are Not John Doe.";
		 }
	return 0;
}

  • 0

Hi Prickly,

Some problems, tolower seems to expect one character, and it returns an int.

http://www.cplusplus.com/reference/clibrar...pe/tolower.html

So you need to loop through each character in your name (you know the number of times you have to loop by checking the length of your string), and convert them one by one.

  • 0

Thanks for the help!

I am just really having a hard time understanding this. :(

I tried to just use the code on that cplusplus website and replace it with my variables but it didn't work. :/

#include<iostream>
#include <cctype>
#include<string>
using namespace std;

int main()
{
	int i=0;
	char johndoe[] = "john doe";
	char name[50];

	cout << "Please Enter Your First And Last Name.\n" << endl;

	cin.getline(name, 50, '\n');

	while (johndoe[i])
	{
		  name=johndoe[i];
		  putchar (tolower(name));
		  i++;
		  }


   if (strcmp(johndoe, name) = 0 ){

	cout << "You Are John Doe.\n";
	}
	else {
		 cout << "You Are Not John Doe.";
		 }
	return 0;
}

It just comes up with the char to int problem and incompatible types in assignment of `char' to `char[50] messages.

So I need to just do them one by one and keep looping? Isn't there a better way? What if I wanted to compare multiple strings, I would have to do a loop for each one then?

  • 0

You can also make it a bit more complex and make use of the <algorithm> header:

#include &lt;iostream&gt;
#include &lt;string&gt;
#include &lt;algorithm&gt;
#include &lt;cctype&gt;

int main ()
{
	std::string x = "John Doe";

	// transform(iterator start, iterator finish, iterator initialResultPosition, UnaryFunction op);
	// initialResultPosition - where to start storing the result for each iteration
	// (it is automatically incremented each iteration)
	// op - a pointer to a function
	std::transform(x.begin(), x.end(), x.begin(), toupper);
	std::cout &lt;&lt; x &lt;&lt; std::endl;
}

If you need more info, feel free to check out cplusplus.com's entry on the transform algorithm or cppreference.com's entry on the transform algorithm (or both). Note that cppreference keeps things simple. cplusplus.com prefers to give examples, and specify a LOT more on the page, which can make it difficult to figure out what you need to read.

Edit:

If you want to still do it without the algorithm, here it is:

for (int i = 0; i &lt; someString.length(); i++)
	someString[i] = toupper(someString[i]);

Edited by rpgfan
  • 0

Thanks rpg, I used the second code you posted and it works.

#include&lt;iostream&gt;
#include &lt;cctype&gt;
#include&lt;string&gt;
#include &lt;algorithm&gt;
using namespace std;

int main()
{

	string x = "john doe";
	string y;

	cout &lt;&lt; "Please Enter Your First And Last Name.\n" &lt;&lt; endl;

	getline(cin, y, '\n');

   for (int i = 0; i &lt; y.length(); i++)
	y[i] = tolower(y[i]);

   if (strcmp (x,y) == 0);
   {
			  cout &lt;&lt; "You Are John Doe.";

   cin.get();
}

The only problem is strcmp, it says I need two const chars, does that mean I have to save the results of the tolower function to chars somehow and then run strcmp?

  • 0

You shouldn't need to use strcmp. You can just use the '==' operator when you use C++ strings. :)

However, if you really needed to use strcmp, you would use strcmp(x.c_str(), y.c_str()). The c_str member function returns a C-string, a null-terminated array of chars.

  • 0
  rpgfan said:
You shouldn't need to use strcmp. You can just use the '==' operator when you use C++ strings. :)

However, if you really needed to use strcmp, you would use strcmp(x.c_str(), y.c_str()). The c_str member function returns a C-string, a null-terminated array of chars.

Hehe oh, ok.

Works perfectly now thanks!

#include&lt;iostream&gt;

using namespace std;

int main()
{

	string x = "john doe";
	string y;

	cout &lt;&lt; "Please Enter Your First And Last Name.\n" &lt;&lt; endl;

	getline(cin, y, '\n');

   for (int i = 0; i &lt; y.length(); i++)
	y[i] = tolower(y[i]);

   if ( x == y )
   {
			  cout &lt;&lt; "You Are John Doe.";
			  }
   else 
   {
		cout &lt;&lt; "You Are Not John Doe.";
		}

   cin.get();
}

Here it is if anyone other beginner ever needs it as a reference. :p

  • 0

Oh, and I should note that the loop should actually use an unsigned integer, not a signed integer, which is the default if no signed/unsigned specifier is...specified.

The reason for this is because the length member function returns a size. Obviously, you can have a zero-length (empty) string, but you can't go any lower than 0, which is why it should be unsigned. In fact, gcc complains about comparing a signed value (the loop variable) with an unsigned value (x.length()).

Happy coding! :)

  • 0

Quickly threw this together. Untested - but should work.

#include &lt;iostream&gt;
#include &lt;string&gt;

int main()
{
	std::string name;
	std::string nameCompare = "John Doe";

	std::cout &lt;&lt; "Enter name: ";
	getline(std::cin, name);

	if (name.compare(nameCompare) == 0)
	{
		std::cout &lt;&lt; "identical" &lt;&lt; std::endl;
	}
	else
	{
		std::cout &lt;&lt; "not identical" &lt;&lt; std::endl;
	}
}

EDIT: Nevermind, didn't see that you wanted to check for varying cases.

This topic is now closed to further replies.
  • Recently Browsing   0 members

    • No registered users viewing this page.
  • Posts

    • For anyone looking for a lightweight formatting-free text editor, I recommend Notepad3.
    • This looks really dumb, especially if it costs $100+. Noone who cares about using a flight yoke would touch that thing, people who don't care are probably fine using the analog sticks on their controller, so who is it for?
    • A) "they shouldn't be making money off of those [free videos]"?? That is literally their business model, making money off videos that users post...if you don't feel like that should be allowed, then are you saying YouTube shouldn't exist. B) Yes, the example I gave is a net-negative transaction. If YouTube makes money from others who are following their rules, it doesn't change the fact that the person using an ad-blocker is costing them money. C) YouTube has always operated at a loss...kind of invalidates your entire argument. As I always say, I don't care what you do, I will not even say you are wrong for doing it. That is purely your choice. Just be honest enough to say something like "Google is rich, I honestly don't care." Perfectly fine reason. Don't act like there is some imagined justification for why it isn't breaking the rules.
    • You can now present content from your camera feed in Google Meet by David Uzondu Google has a new feature rolling out for Google Meet that lets you directly present video from an external camera feed right into your meetings. This means if you have a document camera for showing physical papers, a dedicated external camera for a better angle, or even output from a video production tool, you can now pipe that into Meet as a presentation source. This new option supports video up to 1080p at 30FPS. This "present from camera" function offers a more integrated way to handle certain video inputs compared to some existing workarounds. For instance, it might prove less complicated than a setup with OBS Studio where you arrange your various video sources into scenes, activate the virtual camera output, and then navigate Google Meet's settings to specifically choose "OBS Virtual Camera" as your video input before you can even start presenting that customized feed. Alongside this camera presentation feature, Google's announcement also mentioned several improvements to the general screen sharing experience in Meet. Initiating any type of screen share is faster now, and video quality during screen sharing has also been sharpened, with better handling of dynamic content like scrolling text or embedded videos. To reduce interruptions, if a second presenter stops sharing their screen, any previous presentation will now automatically resume. For those wondering when they can get their hands on this, the rollout for the camera presentation feature and these screen sharing enhancements has begun for Rapid Release domains. Users on Scheduled Release domains will start seeing it from June 11, 2025. Google notes that it could take up to 15 days for these features to be visible to all eligible users. Most Google Workspace accounts, including Business Standard and Plus, various Enterprise and Education tiers, and Workspace Individual subscribers, will have access. This new presentation option joins other recent Google Workspace enhancements. For instance, Gemini in Google Drive can now summarize changes to your files, offering a quick way to get updated on what you missed in documents since you last opened them.
  • Recent Achievements

    • First Post
      James courage Tabla earned a badge
      First Post
    • Reacting Well
      James courage Tabla earned a badge
      Reacting Well
    • Apprentice
      DarkShrunken went up a rank
      Apprentice
    • Dedicated
      CHUNWEI earned a badge
      Dedicated
    • Collaborator
      DarkShrunken earned a badge
      Collaborator
  • Popular Contributors

    1. 1
      +primortal
      382
    2. 2
      +FloatingFatMan
      177
    3. 3
      ATLien_0
      174
    4. 4
      snowy owl
      169
    5. 5
      Xenon
      134
  • Tell a friend

    Love Neowin? Tell a friend!