麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

C語(yǔ)言風(fēng)格字符串

2019-11-14 11:13:47
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

C語(yǔ)言風(fēng)格字符串


這里寫(xiě)圖片描述


字符串的長(zhǎng)度:

C語(yǔ)言風(fēng)格的字符串末尾有一個(gè)‘/0’。比如: char * = "HelloWorld"; 在堆內(nèi)存中會(huì)有一個(gè)字符數(shù)組,它存儲(chǔ)的是“HelloWorld”末尾有一個(gè)“/0” 在棧內(nèi)存中會(huì)有一個(gè)字符指針,名字為str指向字符數(shù)組0號(hào)位置的字符‘H’ 如下圖所示:

這里寫(xiě)圖片描述

那么如何求字符串的長(zhǎng)度呢?定義一個(gè)指針p指向0號(hào)位置,然后再定義一個(gè)變量初始化為0;把指針p不斷往后移動(dòng),移動(dòng)的過(guò)程中將那個(gè)變量不斷加一;最終p所指向的字符是’/0’;這時(shí)候停止循環(huán)返回定義的變量的值。

求字符串的長(zhǎng)度的代碼:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//求字符串的長(zhǎng)度int strLength(char* str){ int count=0; //count記錄字符串的長(zhǎng)度 char* p=str; //定義一個(gè)指針指向第一個(gè)字符 while(*p++){ //當(dāng)p沒(méi)有指向'/0'時(shí),則一直循環(huán)往后移動(dòng),直到指向'/0' count++; //移動(dòng)的過(guò)程中count增大 } return count;}int main(int argc, char **argv) { char* str=(char*)malloc(sizeof(char)*Max); scanf("%s",str);

字符串的拷貝:

當(dāng)考慮目標(biāo)字符串dest比源字符串src短時(shí):

這里寫(xiě)圖片描述

當(dāng)考慮目標(biāo)字符串dest比源字符串src長(zhǎng)時(shí):

這里寫(xiě)圖片描述

求字符串的拷貝的代碼:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串的拷貝void strCopy(char* dest,char* src){ char* p=dest; char* q=src; while(*p++=*q++){ //不斷把q所指向的字符向p所指向的字符移動(dòng),直到q所指向的字符為'/0' }}int main(int argc, char **argv) { char* dest=(char*)malloc(Max*sizeof(char)); char* src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strCopy(dest,src); //自己編寫(xiě)的字符串拷貝函數(shù) printf("%s/n",dest); free(dest); free(src); dest=(char*)malloc(Max*sizeof(char)); src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strcpy(dest,src); //c語(yǔ)言自帶的字符串拷貝函數(shù) printf("%s/n",dest); free(dest); free(src); return 0;}

字符串的連接:

這里寫(xiě)圖片描述

首先要保證目標(biāo)串的尾部,有足夠的空間容納源字符串;步驟:1.求目標(biāo)字符串的長(zhǎng)度2.將源字符串復(fù)制到目標(biāo)串的尾部

字符串的連接的代碼:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串的連接void strCat(char* dest,char* src){ int len=strlen(dest); //求目標(biāo)字符串的長(zhǎng)度 char* p=dest+len; //指針指向目標(biāo)串的末尾,也就是指向dest字符串的'/0'的位置 strcpy(p,src); //將源串拷貝至目標(biāo)串末尾}int main(int argc, char **argv) { char* dest=(char*)malloc(Max*sizeof(char)); char* src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strCat(dest,src); //自己編寫(xiě)的字符串的連接 printf("%s/n",dest); free(dest); free(src); dest=(char*)malloc(Max*sizeof(char)); src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strcat(dest,src); //c語(yǔ)言自帶字符串的連接 printf("%s/n",dest); free(dest); free(src); return 0;}

字符串的比較:

原則:相等返回0,小于返回-1,大于返回1方法:1.定義兩個(gè)指針,分別指向兩個(gè)字符串2.兩個(gè)指針往后移動(dòng),直到指向的連個(gè)字符不相等時(shí)比較大小3.當(dāng)都指向了末尾,且之前的都相等,則返回0;4.當(dāng)長(zhǎng)度不相等,且兩個(gè)指針有一個(gè)指向的’/0’,則長(zhǎng)度長(zhǎng)的大

字符串的比較的代碼:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//比較兩個(gè)字符串的大小int strCompare(char* s1,char* s2){ char* p=s1; char* q=s2; while(*p==*q&&*p&&*q){ //當(dāng)指向的字符相等,且都沒(méi)有指向末尾'/0'時(shí)則循環(huán)往后移動(dòng)指針 p++; q++; } if(*p-*q==0){ //當(dāng)都指向末尾'/0'時(shí),則相等 return 0; }else{ return *p>*q?1:-1; //指向的字符不等時(shí),比較大小;或者有一個(gè)指向'/0'也比較大小 }}int main(int argc, char **argv) { char* s1=(char*)malloc(Max*sizeof(char)); char* s2=(char*)malloc(Max*sizeof(char)); gets(s1); gets(s2); printf("%d/n",strCompare(s1,s2)); //自己寫(xiě)的字符串比較函數(shù) free(s1); free(s2); s1=(char*)malloc(Max*sizeof(char)); s2=(char*)malloc(Max*sizeof(char)); gets(s1); gets(s2); printf("%d/n",strcmp(s1,s2)); //系統(tǒng)自帶的字符串比較函數(shù) free(s1); free(s2); return 0;}

字符串的大小寫(xiě)轉(zhuǎn)換:

大寫(xiě)轉(zhuǎn)化為小寫(xiě):指針指向的字符加上32小寫(xiě)轉(zhuǎn)化為大寫(xiě):指針指向的字符加減32

字符串的大寫(xiě)轉(zhuǎn)化為小寫(xiě):

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串轉(zhuǎn)小寫(xiě)void strLower(char* s){ char* p=s; while(*p){ if(*p>='A'&&*p<='Z'){ *p+=32; //遇到大寫(xiě)字符,加上32 } p++; }}int main(int argc, char **argv) { char* s=(char*)malloc(Max*sizeof(char)); gets(s); strLower(s); //自己寫(xiě)的大寫(xiě)轉(zhuǎn)化為小寫(xiě) printf("%s/n",s); free(s); s=(char*)malloc(Max*sizeof(char)); gets(s); strlwr(s); //c語(yǔ)言自帶轉(zhuǎn)化為小寫(xiě) printf("%s/n",s); free(s); return 0;}

字符串的小寫(xiě)轉(zhuǎn)化為大寫(xiě):

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串轉(zhuǎn)大寫(xiě)void strUper(char* s){ char* p=s; while(*p){ if(*p>='a'&&*p<='z'){ *p-=32; //遇到小寫(xiě)字符,減去32 } p++; }}int main(int argc, char **argv) { char* s=(char*)malloc(Max*sizeof(char)); gets(s); strUper(s); //自己寫(xiě)的小寫(xiě)轉(zhuǎn)化為大寫(xiě) printf("%s/n",s); free(s); s=(char*)malloc(Max*sizeof(char)); gets(s); strupr(s); //c語(yǔ)言自帶轉(zhuǎn)化為大寫(xiě) printf("%s/n",s); free(s); return 0;}
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久亚洲成人 | 欧美性生交xxxxx免费观看 | 视频一区二区三区视频 | 日本在线播放一区二区 | 2021国产精品视频 | 色呦呦一区二区三区 | 国产91一区二区三区 | 久久久一区二区三区精品 | 狠狠干天天操 | 久久精品亚洲国产奇米99 | 欧洲成人在线视频 | 亚洲免费永久 | 成人免费区 | 人人做人人看 | 免费毛片观看 | 午夜国内精品a一区二区桃色 | 一级电影免费 | 精品一区二区三区免费毛片 | 毛片免费大全短视频 | 国产在线地址 | 九九热在线免费观看视频 | 久久精品无码一区二区三区 | 精品久久久久久久久久久久 | 日本aaaa片毛片免费观看视频 | 毛片免费看的 | va免费视频 | 久久久久久久久久网 | 美女羞羞视频在线观看 | av在线免费观看网 | 得得啪在线 | 欧美四级在线观看 | 亚洲欧美在线视频免费 | 久久久久久久一区 | 久久亚洲美女视频 | 亚洲免费观看视频 | 黄色片网站在线免费观看 | 欧美日韩在线视频一区二区 | 亚洲第五色综合网 | 一级国产免费 | 亚欧美一区二区 | 日本在线视频免费观看 |