str -- 通常,程序員喜歡用它作字符串變量名。它是 string(英文詞、字符串的縮寫)
成都創(chuàng)新互聯(lián)公司專注于企業(yè)成都營(yíng)銷網(wǎng)站建設(shè)、網(wǎng)站重做改版、豐鎮(zhèn)網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、html5、商城網(wǎng)站定制開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為豐鎮(zhèn)等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
Str函數(shù),返回代表一數(shù)值的 Variant(String)。語(yǔ)法Str(number)必要的 number 參數(shù)為一 Long,其中可包含任何有效的數(shù)值表達(dá)式。說(shuō)明當(dāng)一數(shù)字轉(zhuǎn)成字符串時(shí),總會(huì)在前頭保留一空位來(lái)表示正負(fù)。
擴(kuò)展資料:
如果 number 為正,返回的字符串包含一前導(dǎo)空格暗示有一正號(hào)。使用 Format 函數(shù)可將數(shù)值轉(zhuǎn)成必要的格式,如日期、時(shí)間、貨幣或其他用戶自定義格式。與 Str 不同的是,F(xiàn)ormat 函數(shù)不包含前導(dǎo)空格來(lái)放置 number 的正負(fù)號(hào)。
注意 Str 函數(shù)只視句點(diǎn) (.) 為有效的小數(shù)點(diǎn)。如果使用不同的小數(shù)點(diǎn)(例如,國(guó)際性的應(yīng)用程序),可使用 CStr 將數(shù)字轉(zhuǎn)成字符串。
.;
以此類推
第二個(gè)式子和第一個(gè)式子差不多
可以說(shuō)第2個(gè)式子就是
strcpy函數(shù)的工作原理
首先將k定為數(shù)組下界
然后每次循環(huán)自減1
n為制定的循環(huán)次數(shù)
這個(gè)循環(huán)是將后一項(xiàng)數(shù)組元素賦值給前一項(xiàng)
也就實(shí)現(xiàn)了你說(shuō)的將第m個(gè)字符后面的字符順序向前移動(dòng)一個(gè)位置
別說(shuō)你沒學(xué)數(shù)組
不知道下界.,str[1+1]).;
也就是strcpy(str[0]..;
也就是strcpy(str[1]str[]表示這是個(gè)數(shù)組
m是一個(gè)變量
舉個(gè)列子你就知道了
當(dāng)m=0時(shí)這個(gè)式子等價(jià)于strcpy(str[0],str[2])?
當(dāng)m=1時(shí)這個(gè)式子等價(jià)于strcpy(str[1]..,str[0+1])..
那你的好好補(bǔ)補(bǔ)基礎(chǔ),str[1]).;
strcpy()函數(shù)是干什么的不要多說(shuō)吧
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的長(zhǎng)度(不包括'\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)位置。簡(jiǎn)單的說(shuō),若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;
}
int ishave;
char string[],charch;
int search(char str[ ],char ch)
{
int i,length,xiabiao=0;
length = strlen(str);
for(i=0;ilength,xiabiao==0;i++)
{
if (str[i]==ch)
{xiabiao = i;}
}
return xiabiao;
}
int main()
{
printf("請(qǐng)輸入字符串:\n");
scanf("%s",string[]);
printf("請(qǐng)輸入字符:\n");
scanf("%c",charch);
ishave = search(string[],charch);
if (ishave==0)
{printf("字符串“%s”中沒有“%c”這個(gè)字符,或者字符串“%s”中“%c”這個(gè)字符對(duì)應(yīng)的元素的下標(biāo)為“0”。\n",string[],charch,string[],charch);}
else
{printf("字符串“%s”中“%c”這個(gè)字符對(duì)應(yīng)的元素的下標(biāo)為“%d”。\n",string[],charch,ishave);}
return 0;
}
1、puts函數(shù)——輸出字符串的函數(shù)
一般的形式為puts(字符串組)
作用:將一個(gè)字符串輸出到終端。如,char一個(gè)string,并賦予初值。調(diào)用puts(string);進(jìn)行字符串的輸出。
2、gets函數(shù)——輸入字符串的函數(shù)
一般的形式:gets(字符數(shù)組)
作用:從終端輸入一個(gè)字符串到字符數(shù)組,并且得到一個(gè)函數(shù)值成為字符數(shù)組的起始地址。
gets(str);
鍵盤輸入,,,,你懂得。
注意:puts和gets函數(shù)只能輸出或者輸入一個(gè)字符串。
3、strcat函數(shù)——字符串連接函數(shù)
一般的形式:strcat(字符數(shù)組1,字符數(shù)組2);
作用:把兩個(gè)字符串?dāng)?shù)組中字符串連接起來(lái),把字符串2連接到字符串1的后面。
說(shuō)明:字符數(shù)組1必須足夠大,以便容納連接后的新字符串。
4、strcpy/strncpy函數(shù)——字符串復(fù)制函數(shù)
一般形式:strcpy(字符數(shù)組1,字符串2);
作用:將字符串2復(fù)制到字符數(shù)組1中去。
如:char str1[10],str2[]="DongTeng";
strcpy(str1,str2);
執(zhí)行后的結(jié)果為:你懂得
注意:
1. 不能用賦值語(yǔ)句直接將一個(gè)字符串常量或者字符數(shù)組直接給一個(gè)字符數(shù)組。
2. 用strncpy可以賦值指定的位置的字符。strncpy(str1,str2,3);將str2中的第3個(gè)字符復(fù)制到str1中。
5、strcmp函數(shù)——字符串比較函數(shù)
一般形式:strcmp(字符串1,字符串2);
作用:用來(lái)比較兩個(gè)字符串的差異。具有不同的比較規(guī)則。
6、strlen函數(shù)——測(cè)字符串長(zhǎng)度的函數(shù)
一般形式:strlen(字符數(shù)組);
如:char str[10]="DongTeng";
printf("%d",strlen(str));
得到的結(jié)果是:5
7、strlwr函數(shù)——轉(zhuǎn)換為小寫的函數(shù)
一般形式:strlwr(字符串);
8、strupr函數(shù)——轉(zhuǎn)換為大寫的函數(shù)
一般形式:strupr(字符串)。
#include?stdio.h
/*比較兩個(gè)字符串*/
/*src、dst相等?return?1*/
/*src比dst短?return?-2*/
/*src比dst長(zhǎng)?return?2*/
/*src、dst長(zhǎng)度一致但不相等?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;
}
}
/*合并兩個(gè)字符串*/
void?mergeString(char*?str1,?char*?str2,?char*?merge)?{
while?(*merge++?=?*str1++);?/*復(fù)制str1并將指針移動(dòng)到字符串的末尾的下一個(gè)位置*/
merge--;?/*退到字符串的末尾*/
while?(*merge++?=?*str2++);?/*從末尾(\0)的位置開始將str2拷貝進(jìn)來(lái)*/
*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é)果