I'm trying to run an isalpha check on an entered string but the issue is, that isalpha works only for individual characters apparently. If I run it like this on a string, I get a segmentation fault.
There might be a more elegant solution, but I can not find a way to connect the string with the char array which is the only missing piece
#include <stdio.h>
#include <cs50.h>
#include <ctype.h>
#include <string.h>
int i;
int main (void)
{
string text = get_string("Text: \n");
int lenght = strlen(text);
if(isalpha(text))
{
printf("Well done");
}
else
{
printf("You suck");
}
So I tried to transform the string into each individual char array. dispate the fact that there might be a more elegant solution, I can not find a way to connect the string with the char array which is the only missing piece
#include <stdio.h>
#include <cs50.h>
#include <ctype.h>
#include <string.h>
int i;
int main (void)
{
string text = get_string("Text: \n");
int lenght = strlen(text);
char letter[lenght];
for(i = 0; i < lenght; i++)
{
printf("Letter %i is %c\n", i, letter[i]);
}
}
Any piece of advice how I can run the isalpha check on my string before I continue to the actual function?
Just write a function that will perform such a check.
It can look the following way as it is shown in the demonstrative program below.
#include <stdio.h>
#include <ctype.h>
int is_all_alpha( const char *s )
{
while ( *s && isalpha( ( unsigned char )*s ) ) ++s;
return *s == '\0';
}
int main(void)
{
char *s1 = "Hello";
char *s2 = "2021";
printf( "\"%s\" is %sa valid word\n", s1, is_all_alpha( s1 ) ? "" : "not " );
printf( "\"%s\" is %sa valid word\n", s2, is_all_alpha( s2 ) ? "" : "not " );
return 0;
}
The program output is
"Hello" is a valid word
"2021" is not a valid word
Or using the definition of the name string
the program can look like
#include <stdio.h>
#include <ctype.h>
#include <cs50.h>
int is_all_alpha( string s )
{
while ( *s && isalpha( ( unsigned char )*s ) ) ++s;
return *s == '\0';
}
int main(void)
{
string s1 = "Hello";
string s2 = "2021";
printf( "\"%s\" is %sa valid word\n", s1, is_all_alpha( s1 ) ? "" : "not " );
printf( "\"%s\" is %sa valid word\n", s2, is_all_alpha( s2 ) ? "" : "not " );
return 0;
}
Though it is much better to declare the function parameter as having the type const char *
instead of string
because within the function is_all_alpha
the pointed string is not changed. And the type const string
is not the same as the type const char *
. The type const string
is an alias for the type char * const
that is it means that the passed pointer itself is constant not the string pointed to by the pointer.
Instead of the conditional operator used in the calls of printf you can use if-else statements. For example
if ( is_all_alpha( text ) )
{
// all symbols of text are letters
// do something
}
else
{
// text contains a non-alpha symbol
// do something else
}