一、字符數(shù)組的定義
為青白江等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及青白江網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站設(shè)計、做網(wǎng)站、青白江網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
一維字符數(shù)組:用于存儲和處理1個字符串,其定義格式與一維數(shù)值數(shù)組一樣。
char str[20];
二維字符數(shù)組:用于同時存儲和處理多個字符串,其定義格式與二維數(shù)值數(shù)組一樣。
char country[10][20];
country[i]:第i個字符串
二.字符數(shù)組的初始化
字符數(shù)組的初始化.
1.可以通過為每個數(shù)組元素指定初值字符來實(shí)現(xiàn)。
char str[10]={ 'I',' ','a','m',' ',‘h’,'a','p','p','y'};
char str[ ]={"I am happy"}; 可以省略花括號,如下所示
char str[ ]="I am happy";
char country[10][20]={“china”,”japanese”,……};
注意:上述這種字符數(shù)組的整體賦值只能在字符數(shù)組初始化時使用,不能用于字符數(shù)組的賦值,字符數(shù)組的賦值只能對其元素一一賦值,下面的賦值方法是錯誤的
char str[15];
str="I am happy";
strcpy(str, "I am happy");
不是用單個字符作為初值,而是用一個字符串(注意:字符串的兩端是用雙引號“”而不是單引號‘’括起來的)作為初值。
‘a(chǎn)’ “a”區(qū)別
三、字符數(shù)組的引用
字符數(shù)組的逐個字符引用,與引用數(shù)值數(shù)組元素類似。
(1)字符數(shù)組的輸入
除了可以通過初始化使字符數(shù)組各元素得到初值外,也可以使用getchar()或scanf()函數(shù)輸入字符。
例如:
char str[10];
…… for(i=0; i10; i++)
{ scanf(\"%c\", str);
fflush(stdin); /*清除鍵盤輸入緩沖區(qū)*/
}
這里只是一部分具體你查看這里:
C語言的字符數(shù)組有兩種,比較方式也有所不同。
1 字符串。
C語言的字符串是用字符數(shù)組表示的。約定以'\0'(ascii碼0)作為結(jié)尾標(biāo)記。
對于字符串類的字符數(shù)組,可以用string.h中的strcmp函數(shù)進(jìn)行比較。
int strcmp(char *str1, char *str2);
其比較規(guī)則為:
a, 從左向右依次比較每個元素;
b, 如果出現(xiàn)str1的元素ascii碼比較大,則返回1;如果出現(xiàn)str2元素ascii碼比較大,則返回-1。如果相等,則繼續(xù)。
c, 如果一直相等,直到遇到\0,這時檢查是否均為\0,如果均為\0,那么返回0;
d, 如果str1到\0,而str2沒到,返回-1; 否則返回1。
總結(jié)規(guī)則就是,如果str1比str2大,返回1;如果相等,返回0;如果str1小,返回-1。
2 不帶\0結(jié)束的字符數(shù)組。
對于此類數(shù)組,沒有庫函數(shù)可供使用,只能自己寫函數(shù)進(jìn)行比較。規(guī)則可以仿照strcmp的規(guī)則。
由于沒有\(zhòng)0作為結(jié)束,所以參數(shù)中必須傳入每個數(shù)組的元素個數(shù)。
int char_array_cmp(char *s1, int l1, char *s2, int l2)
{
int lmin = l1l2? l2:l1; //較小長度者。
int i;
for(i = 0; i lmin; i ++)
if(s1[i] s2[i]) return 1;
else if(s1[i] s2[i]) return -1;
//運(yùn)行到這里,表示所有已判斷元素均相等。
if(l1 == l2) return 0;
if(l1 l2) return 1;
return -1;//l1 l2的情況。
}
c語言字符數(shù)組使用方法
導(dǎo)語:字符數(shù)組是一個存儲字符的數(shù)組,而字符串是一個用雙括號括起來的以'/0'結(jié)束的字符序列,下面就由我為大家介紹一下c語言字符數(shù)組使用方法,希望對大家有所幫助!
1、字符數(shù)組的定義與初始化
字符數(shù)組的初始化,最容易理解的方式就是逐個字符賦給數(shù)組中各元素。
char str[10]={ 'I',' ','a','m',' ',‘h','a','p','p','y'};
即把10個字符分別賦給str[0]到str[9]10個元素
如果花括號中提供的字符個數(shù)大于數(shù)組長度,則按語法錯誤處理;若小于數(shù)組長度,則只將這些字符數(shù)組中前面那些元素,其余的元素自動定為空字符(即 '/0' )。
2、字符數(shù)組與字符串
在c語言中,將字符串作為字符數(shù)組來處理。(c++中不是)
在實(shí)際應(yīng)用中人們關(guān)心的是有效字符串的長度而不是字符數(shù)組的長度,例如,定義一個字符數(shù)組長度為100,而實(shí)際有效字符只有40個,為了測定字符串的實(shí)際長度,C語言規(guī)定了一個“字符串結(jié)束標(biāo)志”,以字符'/0'代表。如果有一個字符串,其中第10個字符為'/0',則此字符串的有效字符為9個。也就是說,在遇到第一個字符'/0'時,表示字符串結(jié)束,由它前面的字符組成字符串。
系統(tǒng)對字符串常量也自動加一個'/0'作為結(jié)束符。例如"C Program”共有9個字符,但在內(nèi)存中占10個字節(jié),最后一個字節(jié)'/0'是系統(tǒng)自動加上的。(通過sizeof()函數(shù)可驗(yàn)證)
有了結(jié)束標(biāo)志'/0'后,字符數(shù)組的長度就顯得不那么重要了,在程序中往往依靠檢測'/0'的位置來判定字符串是否結(jié)束,而不是根據(jù)數(shù)組的`長度來決定字符串長度。當(dāng)然,在定義字符數(shù)組時應(yīng)估計實(shí)際字符串長度,保證數(shù)組長度始終大于字符串實(shí)際長度。(在實(shí)際字符串定義中,常常并不指定數(shù)組長度,如char str[ ])
說明:''代表ASCII碼為0的字符,從ASCII碼表中可以查到ASCII碼為0的字符不是一個可以顯示的字符,而是一個“空操作符”,即它什么也不干。用它來作為字符串結(jié)束標(biāo)志不會產(chǎn)生附加的操作或增加有效字符,只起一個供辨別的標(biāo)志。
對C語言處理字符串的方法由以上的了解后,再對字符數(shù)組初始化的方法補(bǔ)充一種方法――即可以用字符串常量來初始化字符數(shù)組:
char str[ ]={"I am happy"}; 可以省略花括號,如下所示
char str[ ]="I am happy";
注意:上述這種字符數(shù)組的整體賦值只能在字符數(shù)組初始化時使用,不能用于字符數(shù)組的賦值,字符數(shù)組的賦值只能對其元素一一賦值,下面的賦值方法是錯誤的
char str[ ];
str="I am happy";
不是用單個字符作為初值,而是用一個字符串(注意:字符串的兩端是用雙引號“”而不是單引號‘'括起來的)作為初值。顯然,這種方法更直觀方便。(注意:數(shù)組str的長度不是10,而是11,這點(diǎn)請務(wù)必記住,因?yàn)樽址A?I am happy"的最后由系統(tǒng)自動加上一個'/0')
因此,上面的初始化與下面的初始化等價
char str[ ]={'I',' ','a','m',' ','h','a','p','p','y','/0'};
而不與下面的等價
char str[ ]={'I',' ','a','m',' ','h','a','p','p','y'};
前者的長度是11,后者的長度是10.
說明:字符數(shù)組并不要求它的最后一個字符為'/0',甚至可以不包含'/0',向下面這樣寫是完全合法的。
char str[5]={'C','h','i','n','a'};
++++++++
可見,用兩種不同方法初始化字符數(shù)組后得到的數(shù)組長度是不同的。
#include
void main(void)
{
char c1[]={'I',' ','a','m',' ','h','a','p','p','y'};
char c2[]="I am happy";
int i1=sizeof(c1);
int i2=sizeof(c2);
printf("%d",i1);
printf("%d",i2);
}
結(jié)果:10 11
3、字符串的表示形式
在C語言中,可以用兩種方法表示和存放字符串:
(1)用字符數(shù)組存放一個字符串
char str[ ]="I love China";
(2)用字符指針指向一個字符串
char* str="I love China";
對于第二種表示方法,有人認(rèn)為str是一個字符串變量,以為定義時把字符串常量"I love China"直接賦給該字符串變量,這是不對的。
C語言對字符串常量是按字符數(shù)組處理的,在內(nèi)存中開辟了一個字符數(shù)組用來存放字符串常量,程序在定義字符串指針變量str時只是把字符串首地址(即存放字符串的字符數(shù)組的首地址)賦給str。
兩種表示方式的字符串輸出都用
printf("%s",str);
%s表示輸出一個字符串,給出字符指針變量名str(對于第一種表示方法,字符數(shù)組名即是字符數(shù)組的首地址,與第二種中的指針意義是一致的),則系統(tǒng)先輸出它所指向的一個字符數(shù)據(jù),然后自動使str自動加1,使之指向下一個字符...,如此,直到遇到字符串結(jié)束標(biāo)識符 " /0 "。
4、對使用字符指針變量和字符數(shù)組兩種方法表示字符串的討論
雖然用字符數(shù)組和字符指針變量都能實(shí)現(xiàn)字符串的存儲和運(yùn)算,但它們二者之間是有區(qū)別的,不應(yīng)混為一談。
4.1、字符數(shù)組由若干個元素組成,每個元素放一個字符;而字符指針變量中存放的是地址(字符串/字符數(shù)組的首地址),絕不是將字符串放到字符指針變量中(是字符串首地址)
4.2、賦值方式:
對字符數(shù)組只能對各個元素賦值,不能用以下方法對字符數(shù)組賦值
char str[14];
str="I love China"; (但在字符數(shù)組初始化時可以,即char str[14]="I love China";)
而對字符指針變量,采用下面方法賦值:
char* a;
a="I love China";
或者是 char* a="I love China"; 都可以
4.3、對字符指針變量賦初值(初始化):
char* a="I love China";
等價于:
char* a;
a="I love China";
而對于字符數(shù)組的初始化
char str[14]="I love China";
不能等價于:
char str[14];
str="I love China"; (這種不是初始化,而是賦值,而對數(shù)組這樣賦值是不對的)
4.4、如果定義了一個字符數(shù)組,那么它有確定的內(nèi)存地址;而定義一個字符指針變量時,它并未指向某個確定的字符數(shù)據(jù),并且可以多次賦值。
5、字符串處理函數(shù)
5.1
char *strcat(char *str1,const char *2 );
char *strcat(char *strDestination,const char *strSource );
功能:函數(shù)將字符串str2 連接到str1的末端,并返回指針str1
注:連接前兩個字符串的后面都有一個' /0 ',連接時將字符串1后面的 ' /0 ‘去掉,只在新串最后保留一個 ' /0 ‘
5.2
char *strcpy(char *str1,const char *2 );
char *strcpy(char *strDestination,const char *strSource );
功能:復(fù)制字符串strSource中的字符到字符串strDestination,包括空值結(jié)束符。返回值為指針strDestination。
注:1、“字符數(shù)組1”必須寫成數(shù)組名形式,“字符串2"可以是字符數(shù)組名,也可以是一個字符串常量
2、復(fù)制時連同字符串后面的 ' /0 ' 一起復(fù)制到數(shù)組1中
3、不能用賦值語句直接將一個字符串常量或者字符數(shù)組直接賦給一個字符數(shù)組(同普通變量數(shù)組是一樣的),而只能用strcpy函數(shù)處理。
4、可以用strcpy函數(shù)將字符串2中的前若干個字符復(fù)制到字符數(shù)組1中去。
;
#include?stdio.h
/*比較兩個字符串*/
/*src、dst相等?return?1*/
/*src比dst短?return?-2*/
/*src比dst長?return?2*/
/*src、dst長度一致但不相等?return?-1*/
int?stringCmp?(char?*src,?char?*dst)?{??
if?(strlen?(src)??strlen?(dst))
return?-2;
else?if?(strlen?(src)??strlen?(dst))
return?2;
else?{
while?(*src??*dst)?{
if?(*src?!=?*dst)
return?-1;
src++;
dst++;
}
return?1;
}
}
/*合并兩個字符串*/
void?mergeString(char*?str1,?char*?str2,?char*?merge)?{
while?(*merge++?=?*str1++);?/*復(fù)制str1并將指針移動到字符串的末尾的下一個位置*/
merge--;?/*退到字符串的末尾*/
while?(*merge++?=?*str2++);?/*從末尾(\0)的位置開始將str2拷貝進(jìn)來*/
*merge?=?'\0';
}
int?main(void)?{
char?*str1_1="hel",*str1_2="lo",?*merge1;
char?*str2_1="ness",*str2_2="happy",?*merge2;
char?*str3_1="hi",*str3_2="hi",?*merge3;
char?*str4_1="hello",*str4_2="world",?*merge4;
puts?("第1組字符串:");
puts?(str1_1);
puts?(str1_2);
if?(stringCmp?(str1_1,?str1_2)?==?1)
puts?(str1_1);
else?if?(stringCmp?(str1_1,?str1_2)?==?-2)?{
mergeString?(str1_2,?str1_1,?merge1);
puts?(merge1);
}
else?if?(stringCmp?(str1_1,?str1_2)?==?2?||?stringCmp?(str1_1,?str1_2)?==?-1)?{
mergeString?(str1_1,?str1_2,?merge1);
puts?(merge1);
}
putchar?('\n');
puts?("======================================================");
putchar?('\n');
puts?("第2組字符串:");
puts?(str2_1);
puts?(str2_2);
if?(stringCmp?(str2_1,?str2_2)?==?1)
puts?(str2_1);
else?if?(stringCmp?(str2_1,?str2_2)?==?-2)?{
mergeString?(str2_2,?str2_1,?merge2);
puts?(merge2);
}
else?if?(stringCmp?(str2_1,?str2_2)?==?2?||?stringCmp?(str2_1,?str2_2)?==?-1)?{
mergeString?(str2_1,?str2_2,?merge2);
puts?(merge2);
}
putchar?('\n');
puts?("======================================================");
putchar?('\n');
puts?("第3組字符串:");
puts?(str3_1);
puts?(str3_2);
if?(stringCmp?(str3_1,?str3_2)?==?1)
puts?(str3_1);
else?if?(stringCmp?(str3_1,?str3_2)?==?-2)?{
mergeString?(str3_2,?str3_1,?merge3);
puts?(merge3);
}
else?if?(stringCmp?(str3_1,?str3_2)?==?2?||?stringCmp?(str3_1,?str3_2)?==?-1)?{
mergeString?(str3_1,?str3_2,?merge3);
puts?(merge3);
}
putchar?('\n');
puts?("======================================================");
putchar?('\n');
puts?("第4組字符串:");
puts?(str4_1);
puts?(str4_2);
if?(stringCmp?(str4_1,?str4_2)?==?1)
puts?(str4_1);
else?if?(stringCmp?(str4_1,?str4_2)?==?-2)?{
mergeString?(str4_2,?str4_1,?merge4);
puts?(merge4);
}
else?if?(stringCmp?(str4_1,?str4_2)?==?2?||?stringCmp?(str4_1,?str4_2)?==?-1)?{
mergeString?(str4_1,?str4_2,?merge4);
puts?(merge4);
}
putchar?('\n');
puts?("======================================================");
putchar?('\n');
getch?();?/*屏幕暫留*/
return?0;
}
運(yùn)行結(jié)果