美文网首页C语言
C primer plus第十一章:字符串和字符串函数

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

作者: 不知名小号 | 来源:发表于2017-11-07 22:49 被阅读59次

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

    由于方括号[]的优先级要高于*号,所以
    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<stdio.h>
    #include<string.h>
    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<stdio.h>
    #include<string.h>
    
    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<stdio.h>
    #include<string.h>
    #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第十一章:字符串和字符串函数

    相关文章

      网友评论

        本文标题:C primer plus第十一章:字符串和字符串函数

        本文链接:https://www.haomeiwen.com/subject/jdhlmxtx.html