Define a number of functions that can be used to analyze and manipulate C-strings. A C-string is a sequence of characters terminated by the null character, '\0'. Since C is part of C++, C-string implementations are valid in C++ as well as C. Recall that an array of characters is the underlying data structure for storing C-strings. For example, this definition creates such an array. char myString[100]; myString will be capable of holding a C-string with up to 99 characters before the terminating null character. Of course, myString can hold a shorter C-string, too. For example, these examples give myString the value "xyz". myString[0] = 'x'; myString[1] = 'y'; myString[2] = 'z'; myString[3] = '\0'; It is legal to initialize a string variable, char example[100] = "First value"; Now, the string example[100] contains the following: F i r s t v a l u e \0 * * . . . . . * * * * * * * * note that * char indicates an unknown value. myString = "xyz"; // ILLEGAL: Cannot assign to an array Furthermore, you cannot do comparisons like this. if (myString == "xyz") cout << "fantasy land" << endl; The comparison myString == "xyz" is actually legal Following are the 4 basic string library functions that (1) strlen(str) Returns the number of characters in the string, not including the null character. (2) strcmp(str1, str2) This function takes two strings and compares them. If the strings are equal, it returns 0. If the first is greater than the 2nd, then it returns some value greater than 0. If the first is less than the 2nd, then it returns some value less than 0. The ordering for strings is lexical order based on the ASCII value of characters (see http://www.asciitable.com/ (Links to an external site.)). Remember that the ASCII value of 'A' and 'a' (i.e., upper/lowercase) are not the same. Returns an integer value indicating the relationship between the strings: return value meaning strcmp(a, b) < 0 it is a < b , the first character that does not match has a lower value in a than in b. strcmp(a, b) == 0 it is a == b, the contents of both strings are equal strcmp(a, b) >= 0 it is a >= b, the first character that does not match has a greater value in a than in b (3) strcpy(dest, source) Copies the contents of source into dest, An easy way to remember that the destination comes first is because the order is the same as for assignment, e.g: dest = source Also, strcpy() returns the destination string, but that return value is often ignored. Below show an example of how the contents of source being copied into dest, as in: #include char str1[10] = "initvalue"; strcpy(str1, "Second"); S e c o n d \0 u e \0 However, cout << str1 << endl; will only output the word "Second", the artifact of "ue" is just the remnant from the previous string. (4) strcat(dest, source) Copies the contents of the source onto the end of dest, as in: char str2[10] = "first"; strcat(str2, " one"); Now, the string str2 contains the following: "first one"; When using strcat(), make sure the destination is big enough to hold the extra characters. Note: Function strcat() also returns the destination string, but that return value is often ignored. complete your own versions of these four most commonly used standard string functions. Your version: int mystrlen( const char *s) int mystrcmp( const char *s1, const char *s2) char *mystrcpy( char *s1, const char *s2) char *mystrcat( char *s1, const char *s2) C standard string library functions: int strlen( const char *s) int strcmp( const char *s1, const char *s2) char *strcpy( char *s1, const char *s2) char *strcat( char *s1, const char *s2) The mystrlen function should have the same behavior as the C standard strlen function. Your functions should not call any of the standard string functions. In the context of this assignment, you should pretend that the standard string functions do not exist. Pay special attention to boundary cases. In particular, make sure that functions work when given empty strings as arguments. Make sure that the function call mystrlen("") returns 0. Create a file named mystring.cpp containing the implementation of functions. You may use array notation to define your functions. For example, this is an acceptable version of the mystrlen function: int mystrlen(const char pcString[]) { int Length = 0; while (pcString[Length] != '\0') Length++; return Length; } Use pointer notation instead of array notation to define your functions. Define your mystrlen function similar to this: int mystrlen(const char *pcString) { const char *pcStringEnd = pcString; while (*pcStringEnd != '\0') pcStringEnd++; return pcStringEnd - pcString; } The comment of each function should look similar to the example shown below. int mystrlen(const char *pcString) /* Return the length of string pcString. */ { ... } ... Comment explicitly states what the function returns, and explicitly refers to the function's parameter (pcString).
Define a number of functions that can be used to analyze and manipulate C-strings.
A C-string is a sequence of characters terminated by the null character, '\0'. Since C is part of C++, C-string implementations are valid in C++ as well as C.
Recall that an array of characters is the underlying data structure for storing C-strings. For example, this definition creates such an array.
char myString[100];
myString will be capable of holding a C-string with up to 99 characters before the terminating null character. Of course, myString can hold a shorter C-string, too. For example, these examples give myString the value "xyz".
myString[0] = 'x';
myString[1] = 'y';
myString[2] = 'z';
myString[3] = '\0';
It is legal to initialize a string variable,
char example[100] = "First value";
Now, the string example[100] contains the following:
F | i | r | s | t | v | a | l | u | e | \0 | * | * | . . . . . | * | * | * | * | * | * | * | * |
note that * char indicates an unknown value.
myString = "xyz"; // ILLEGAL: Cannot assign to an array
Furthermore, you cannot do comparisons like this.
if (myString == "xyz")
cout << "fantasy land" << endl;
The comparison myString == "xyz" is actually legal
Following are the 4 basic string library functions that
(1) strlen(str)
Returns the number of characters in the string, not including the null character.
(2) strcmp(str1, str2)
This function takes two strings and compares them. If the strings are equal, it returns 0. If the first is greater than the 2nd, then it returns some value greater than 0. If the first is less than the 2nd, then it returns some value less than 0.
The ordering for strings is lexical order based on the ASCII value of characters (see http://www.asciitable.com/ (Links to an external site.)). Remember that the ASCII value of 'A' and 'a' (i.e., upper/lowercase) are not the same.
Returns an integer value indicating the relationship between the strings:
return value | meaning |
---|---|
strcmp(a, b) < 0 | it is a < b , the first character that does not match has a lower value in a than in b. |
strcmp(a, b) == 0 | it is a == b, the contents of both strings are equal |
strcmp(a, b) >= 0 | it is a >= b, the first character that does not match has a greater value in a than in b |
(3) strcpy(dest, source)
Copies the contents of source into dest, An easy way to remember that the destination comes first is because the order is the same as for assignment, e.g:
dest = source
Also, strcpy() returns the destination string, but that return value is often ignored.
Below show an example of how the contents of source being copied into dest, as in:
#include <cstring>
char str1[10] = "initvalue";
strcpy(str1, "Second");
S | e | c | o | n | d | \0 | u | e | \0 |
However, cout << str1 << endl; will only output the word "Second", the artifact of "ue" is just the remnant from the previous string.
(4) strcat(dest, source)
Copies the contents of the source onto the end of dest, as in:
char str2[10] = "first";
strcat(str2, " one");
Now, the string str2 contains the following:
"first one";
When using strcat(), make sure the destination is big enough to hold the extra characters.
Note: Function strcat() also returns the destination string, but that return value is often ignored.
complete your own versions of these four most commonly used standard string functions.
Your version: int mystrlen( const char *s) int mystrcmp( const char *s1, const char *s2) char *mystrcpy( char *s1, const char *s2) char *mystrcat( char *s1, const char *s2) |
C standard string library functions: int strlen( const char *s) int strcmp( const char *s1, const char *s2) char *strcpy( char *s1, const char *s2) char *strcat( char *s1, const char *s2) |
The mystrlen function should have the same behavior as the C standard strlen function.
Your functions should not call any of the standard string functions. In the context of this assignment, you should pretend that the standard string functions do not exist.
Pay special attention to boundary cases. In particular, make sure that functions work when given empty strings as arguments. Make sure that the function call mystrlen("") returns 0.
Create a file named mystring.cpp containing the implementation of functions.
You may use array notation to define your functions. For example, this is an acceptable version of the mystrlen function:
int mystrlen(const char pcString[]) { int Length = 0; while (pcString[Length] != '\0') Length++; return Length; }
Use pointer notation instead of array notation to define your functions. Define your mystrlen function similar to this:
int mystrlen(const char *pcString)
{
const char *pcStringEnd = pcString;
while (*pcStringEnd != '\0')
pcStringEnd++;
return pcStringEnd - pcString;
}
The comment of each function should look similar to the example shown below.
int mystrlen(const char *pcString) /* Return the length of string pcString. */
{
...
}
...
Comment explicitly states what the function returns, and explicitly refers to the function's parameter (pcString).
Step by step
Solved in 2 steps