C primer plus第十一章:字符串和字符串函数

指针数组,还是向数组的指针?

由于方括号[]的优先级要高于*号,所以
char *m[5]表示一个由五个指针构成的数组。

(char *)m[5]表示一个指针,一个指向有五个元素的数组的指针。

数组和指针的区别

char m1[]="abcdefg";
char m2*="abcdefg"

  • m1是一个常量,是不能执行m1++的,但是可以通过m1+1来访问m1的第二个元素。
  • 而m2是个变量,可以进行m2++。
  • m1的值可以赋给m2,但是m2的值不能赋给m1

二维数组和指针数组的区别

char a1[5][81];
char *a2[5]

a1是一个有5个元素的数组,而每个元素又是一个81个char的数组,所以声明a1的时候,就为之声明了5*81个char的空间。
a2是一个含有5个指针的数组,每个指针指向一个字符串,字符串所占用的空间可由初始化字符串时的字符串长度决定。
所以,第二种声明方式比第一种声明方式比较节省空间。

三个输入函数的区别

gets()遇到换行符就会停止输入,它适合用来读取一行字符串。返回一个指向char类型的指针值。
scanf()遇到空格就会停止输入,所以它适合用来读取单词。返回成功读取项目的个数。
fgets()既能读空格又能读换行符,它有三个参数,fget(指针的地址,读入的长度,输入文件),当通过键盘输入时,第三个参数为stdin。
当读到第二个参数的长度或者换行符时,停止读取。

常用的字符串函数

函数都包含在string.h头文件里

strcat()函数

strcat()函数需要两个字符串参数,将第二个字符串的一份拷贝添加到第一个字符串的结尾。从而连接了两个字符串。返回值是第一个参数更新后的值。

strncat()函数

strncat(char * c1,char * c2,int n);
后面的n为读c2的前n个字符,读到第n个字符或者遇到换行符都会停止读取,然后将读取到的字符接到c1的末尾

strcmp()函数

strcmp(cha * c1,char * c2);
顾名思义,string compare,比较c1和c2,
如果c1c完全相同,则返回0。
如果不同,比较第一个c1c2不同的字符,如果c2中的字符的ASCII值大于c1中的字符的ASCII值,返回1,否则,返回-1。

strncmp()函数

strcmp(cha * c1,char * c2,n);
比较c1c1的前n个字符,返回结果与strcmp()函数相同.

strcpy()函数

有两个字符串参数,将第二个字符串参数复制到第一个字符串参数,返回第一个参数的值。
由于字符串的名字只是一个地址,所以在初始化字符串之后就不能再给字符串复制,像这样“str="abcde"
只能strcpy(str,"abcde")”

strchr()函数

char *strchr(const char *s,int c);
返回字符串中存放字符c的第一个位置的指针,如果没有找到该字符,就返回空指针。

//strchr函数
#include
#include
int main()
{
    char *a="abcdefg";//声明一个指针,
    char c='e';
    char *b;//用来存放返回的指针
    b=strchr(a,c);
    printf("%p %p\n",a,b);//输出的结果是两个相差4的地址,因为e字符数组里的第4个元素。
    b=strchr(a,'z');
    printf("%p %p\n",a,b);//输出的b是8个0的空指针
    return 0;
}

strpbrk(const char *s1,const char *s2)函数

返回一个指针,指向s1字符串中存放s2中任一字符串的地方,如果找不到,则返回空指针

#include
#include

int main()
{
    char *s1="abcdefg";
    char *s2="efghijk";//s1和s2中第一个共同的元素是e
    char *a;
    a=strpbrk(s1,s2);
    printf("%p %p %d\n",s1,a,a-s1+1);//第一个地址和第二个地址相差4,e是s1中的第5个元素
    return 0;
}

strrchr(const char *s,int c)

和strchr()类似,不过他返回的是最后一次出现c的地方

字符串排序

原理是冒泡排序加strcmp函数的调用。并不难。

#include
#include
#define SIZE 81
#define LIM 20
#define HALT " "
void stsrt(char *strings[],int num);

int main()
{
    char input[LIM][SIZE];
    char *ptstr[LIM];
    int ct = 0;
    int k;

    printf("Input up to %d lines, and I will sort them.\n",LIM);
    printf("To stop, press the Enter key at a line's start. \n");
    while(ct < LIM && gets(input[ct]) != NULL && input[ct][0] != '\0')
    {
        ptstr[ct] = input[ct];
        ct++;
    }
    stsrt(ptstr, ct);
    puts ("\nHere's the sorted list: \n");
    for(k = 0;k < ct; k++)
        puts(ptstr[k]);
    return 0;
}

void stsrt(char *strings[],int num)
{
    char *temp;
    int top,seek;

    for(top = 0; top < num-1; top++)
        for(seek = top + 1; seek < num ; seek++)
            if(strcmp(strings[top], strings[seek]) > 0)
            {
                temp = strings[top];
                strings[top] = strings [seek];
                strings[seek] = temp;
            }
}

C primer plus第十一章:字符串和字符串函数_第1张图片
图片发自App

你可能感兴趣的:(C primer plus第十一章:字符串和字符串函数)