a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

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

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

2019-11-14 10:23:48
字體:
來(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ā)表
主站蜘蛛池模板: 影音先锋国产 | 视频一区二区中文字幕日韩 | 国产精品一区久久久久 | 中文字幕 亚洲一区 | 欧美日韩成人在线视频 | 五月婷婷六月激情 | 亚洲成人在线视频观看 | 高清视频新国产 | 青草av在线| 亚洲成人av一区二区 | 男人天堂av网站 | 免费看国产片在线观看 | 日本高清视频网站www | 天天天综合网 | 婷婷色5月 | 99视频在线 | 欧美日韩久久精品 | 欧洲另类在线1 | 爱爱视频网站 | 一区二区三区四区在线 | 黄网站在线播放 | 亚洲午夜视频在线观看 | 狠狠色丁香九九婷婷综合五月 | 欧美国产在线一区 | 日韩美女在线视频 | 欧美一级黄色网 | 激情综合色综合久久综合 | 99精品免费| 日产精品久久 | 蜜臀视频在线观看 | 日韩中文在线视频 | 久久99国产精一区二区三区 | 午夜日韩视频 | 久久久精品高清 | 一级毛片视频播放 | 日韩精品毛片 | 四虎成人av| 99亚洲 | 国产美女视频黄a视频免费 国产美女在线播放 | 国产欧美精品一区二区 | 成人在线精品 |