1、打開visual C++ 6.0-文件-新建-文件-C++ Source File。
成都創(chuàng)新互聯(lián)公司主營呼倫貝爾網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都app軟件開發(fā)公司,呼倫貝爾h5小程序定制開發(fā)搭建,呼倫貝爾網(wǎng)站營銷推廣歡迎呼倫貝爾等地區(qū)企業(yè)咨詢
2、定義變量:#include stdio.hvoid main(){? ? char c1,c2,c3;????????????????????????????????????? /*定義字符變量*/。
3、輸入一個(gè)字符:printf("輸入一個(gè)字符,使用getche函數(shù)接收\n");???????? /*提示用戶輸入一個(gè)字符*/ c1=getche();??????????????????????????????????? /*使用getche()函數(shù)接收*/printf("\n");?????????????????????????????????????? /*輸出一行空行*/。
4、輸入一個(gè)字符: printf("輸入一個(gè)字符,使用getch函數(shù)接收\n");? 。
5、輸入一個(gè)字符:printf("輸入一個(gè)字符,使用getchar函數(shù)接收\n")。? /*提示用戶輸入一個(gè)字符*/
c3=getchar(); /*使用getchar()函數(shù)接收*/。
6、輸出結(jié)果:printf("\n輸入的這三個(gè)字符是:\n");? /*輸出一行空行*/ /*將這些字符輸出*/
putchar(c1); putchar(c2);putchar(c3);printf("\n");。
1、strcat()
此函數(shù)原型為 char *strcat(char *dest, const char *src).
功能為連接兩個(gè)字符串,把src連接到dest后面;返回dest地址
實(shí)現(xiàn)如下
[cpp] view plaincopy
char * strcat(char *dest,const char *src)
{
char* addr=dest;
while(*dest)//找到'\0'
{
dest++;
};
while(*dest++=*src++)
{};
return addr;
}
2、strcmp()
此函數(shù)的函數(shù)原型為 int strcmp(const char *str1, const char *str2).
功能為比較兩個(gè)字符串。
當(dāng)str1指向的字符串大于str2指向的字符串時(shí),返回正數(shù)。
當(dāng)str1指向的字符串等于str2指向的字符串時(shí),返回0。
當(dāng)str1指向的字符串小于str2指向的字符串時(shí),返回負(fù)數(shù)。
實(shí)現(xiàn)如下:
[cpp] view plaincopy
int strcmp(const char *str1, const char *str2)
{
while(*str1==*str2)
{
if(*str1=='\0')
return 0;
str1++;
str2++;
}
return *str1-*str2;
}
3、strcpy()
此函數(shù)原型為 char *strcpy(char* dest, const char *src)
功能為拷貝字符串內(nèi)容到目的串,把src所指向的內(nèi)容拷貝到dest
實(shí)現(xiàn)如下
[cpp] view plaincopy
char *strcpy(char *dest,const char *src)
{
//assert(dest!=NULLsrc!=NULL);
char *addr=dest;
while(*dest++=*src++);
return addr;
}
4、strlen()
此函數(shù)原型為unsigned in strlen(const char *str)
功能為返回字符串str的長度(不包括'\0')。
實(shí)現(xiàn)如下:
[cpp] view plaincopy
unsigned int strlen(const char *str)
{
unsigned len=0;
while(*str!='\0')
{
len++;
str++;
}
return len;
}
5、strchr() strrchr()
char *strchr(char *str, char c)
功能為查找str中首次出現(xiàn)c的位置,如有有,則返回出現(xiàn)位置,否則返回NULL。實(shí)現(xiàn)如下:
[cpp] view plaincopy
char *strchr(char *str, char c)
{
while(*str!='\0'*str!=c)
{
str++;
}
return (*str==c? str: NULL);
}
char *strrchr(char *str, char c)
功能為查找str中最后一次出現(xiàn)c的位置,如有有,則返回出現(xiàn)位置,否則返回NULL。實(shí)現(xiàn)如下:
[cpp] view plaincopy
char *strrchr(char *str, char c)
{
char *p=str+strlen(str);//p指向最后一個(gè)字符
while(p!=str*p!=c)
p--;
if(p==str*p!=c)
return NULL;
else return p;
}
6、strcspn() strspn()
strcspn
原型:size_t strcspn(const char *pstr, const char *strCharset)
MSDN解釋為:在字符串pstr中搜尋strCharsret中所出現(xiàn)的字符,返回strCharset中出現(xiàn)的第一個(gè)字符在pstr中的出現(xiàn)位置。簡單的說,若strcspn返回的數(shù)值為n,則代表字符串strCharsrt開頭連續(xù)有n個(gè)字符不包含在pstr內(nèi)的字符。
功能:返回后面字符串中第一個(gè)不在前者出現(xiàn)的下表。
7、strdup()
此函數(shù)原型為char *strdup(const char *str)
功能為拷貝字符串到新建的內(nèi)存,返回內(nèi)存指針。若失敗,返回NULL。要注意,返回的指針指向的內(nèi)存在堆中,所以要手動(dòng)釋放。
函數(shù)實(shí)現(xiàn):
[cpp] view plaincopy
char *strdup(const char *str)
{
char *p=NULL;
if(str(p=(char*)malloc(strlen(str)+1)))
strcpy(p,str);
return p;
8、strrev()
此函數(shù)的原型為char *strrev(char *str)
功能為反轉(zhuǎn)字符串,返回字符串指針。
函數(shù)實(shí)現(xiàn):
[cpp] view plaincopy
char *strrev(char *str)
{
if(str==NULL)
return NULL;
char *start=str;
char *end=str+strlen(str)-1;
char temp;
while(startend)
{
temp=*start;
*start=*end;
*end=temp;
start++;
end--;
}
return str;
}
9、strstr()
函數(shù)原型為char *strstr(const char str1, const char *str2)
功能為查找字符串str2在str1中出現(xiàn)的位置,找到則返回位置,否則返回NULL。
函數(shù)實(shí)現(xiàn):
[cpp] view plaincopy
char *strstr(const char str1, const char *str2)
{
int length1=strlen(str1);
int length2=strlen(str2);
while(length1=length2)
{
length1--;
if(!strncpy(str1,str2,length2))//比較前n個(gè)字符串,類似strcpy
return str1;
str1++;
}
return NULL;
}
C語言中,strstr函數(shù)的功能是尋找字符串中子串出現(xiàn)的位置,自己寫的步驟如下。
需要準(zhǔn)備的材料分別有:電腦、C語言編譯器。
1、首先,打開C語言編譯器,新建一個(gè)初始.cpp文件,例如:test.cpp。
2、在test.cpp文件中,輸入C語言代碼:。
int fun(char *a, char *b)
{
int i, j, alen = strlen(a), blen = strlen(b);
for (i = 0; i alen - blen + 1; i++)
if (a[i] == b[0]) {
for (j = 1; j blen; j++) if (a[i + j] != b[j])break;
if (j == blen)
return i;
}
return -1;
}
3、編譯器運(yùn)行test.cpp文件,此時(shí)成功實(shí)現(xiàn)了strstr實(shí)現(xiàn)了字符串查找。