C: Strings Computer Science Engineering (CSE) Notes | EduRev

GATE Computer Science Engineering(CSE) 2022 Mock Test Series

Computer Science Engineering (CSE) : C: Strings Computer Science Engineering (CSE) Notes | EduRev

The document C: Strings Computer Science Engineering (CSE) Notes | EduRev is a part of the Computer Science Engineering (CSE) Course GATE Computer Science Engineering(CSE) 2022 Mock Test Series.
All you need of Computer Science Engineering (CSE) at this link: Computer Science Engineering (CSE)

Strings are actually one-dimensional array of characters terminated by a null character ''. Thus a null-terminated string contains the characters that comprise the string followed by a null.

The following declaration and initialization create a string consisting of the word "Hello". To hold the null character at the end of the array, the size of the character array containing the string is one more than the number of characters in the word "Hello."

char greeting[6] = {'H', 'e', 'l', 'l', 'o', ''};

If you follow the rule of array initialization then you can write the above statement as follows −

char greeting[] = "Hello";

Following is the memory presentation of the above defined string in C/C++ −

C,CSE,Strings,Programming Langauge,GATE

Actually, you do not place the null character at the end of a string constant. The C compiler automatically places the '' at the end of the string when it initializes the array. Let us try to print the above mentioned string −

#include <stdio.h>

int main () {

char greeting[6] = {'H', 'e', 'l', 'l', 'o', ''};
printf("Greeting message: %s
", greeting );
return 0;
}

When the above code is compiled and executed, it produces the following result −

Greeting message: Hello

C supports a wide range of functions that manipulate null-terminated strings −

S.N.Function & Purpose
1

strcpy(s1, s2);

Copies string s2 into string s1.

2

strlen(s1);

Returns the length of string s1.

3

strcmp(s1, s2);

Returns 0 if s1 and s2 are the same; less than 0 if s1<s2; greater than 0 if s1>s2.

4

strchr(s1, ch);

Returns a pointer to the first occurrence of character ch in string s1.

5

strstr(s1, s2);

Returns a pointer to the first occurrence of string s2 in string s1.

6

strstr(s1, s2);

Returns a pointer to the first occurrence of string s2 in string s1.

The following example uses some of the above-mentioned functions −

#include <stdio.h>
#include <string.h>

int main () {

char str1[12] = "Hello";
char str2[12] = "World";
char str3[12];
int len ;

/* copy str1 into str3 */
strcpy(str3, str1);
printf("strcpy( str3, str1) : %s
", str3 );

/* concatenates str1 and str2 */
strcat( str1, str2);
printf("strcat( str1, str2): %s
", str1 );

/* total lenghth of str1 after concatenation */
len = strlen(str1);
printf("strlen(str1) : %d
", len );

return 0;
}

When the above code is compiled and executed, it produces the following result −

strcpy( str3, str1) :  Hello
strcat( str1, str2): HelloWorld
strlen(str1) : 10
Offer running on EduRev: Apply code STAYHOME200 to get INR 200 off on our premium plan EduRev Infinity!

Related Searches

study material

,

Sample Paper

,

Viva Questions

,

Extra Questions

,

practice quizzes

,

Previous Year Questions with Solutions

,

C: Strings Computer Science Engineering (CSE) Notes | EduRev

,

past year papers

,

Semester Notes

,

C: Strings Computer Science Engineering (CSE) Notes | EduRev

,

video lectures

,

Exam

,

C: Strings Computer Science Engineering (CSE) Notes | EduRev

,

MCQs

,

Objective type Questions

,

Free

,

ppt

,

shortcuts and tricks

,

mock tests for examination

,

pdf

,

Summary

,

Important questions

;