C语言刷题(32):利用指针数组实现在主函数中输入5个等长的字符串。用另一函数对它们进行排序。

小憨总结:
若指针指向两个字符串,则交换时,直接交换指针,而不是指针中的内容,即重新指向,指针中存放的是字符串第一个元素的首地址。
一般定义了二维数组,就要定义,指向一维数组的指针。

#include <stdio.h>
#include <string.h>
void main()
{
    void print(char (*q)[10]);
    void sort(char (*q)[10]);
    char a[5][10] ;          //定义5个一维数组存放字符串
    int i;
    printf("input five strings:\n");
    for(i = 0;i<5;i++)      //输入
    {
        scanf("%s",*(a+i));
    }
    sort(a);                //对五个字符串进行排序
    print(a);               //输出五个字符串
}
void sort(char (*q)[10])    //采用冒泡排序算法,指向一维数组的q指针接受,二维数组名
{
    void swap(char *p,char *q);
    int i,j;
    for(i=0;i<4;i++)
    {
        for(j=4;j>i;j--)
        {
            if(strcmp(*(q+j),*(q+j-1))<0)
            {
                swap(*(q+j),*(q+j-1));
            }
        }
    }
}
void print(char (*q)[10])
{
    int i;
    printf("Output five strings:\n");
    for(i=0;i<5;i++)
    {
        printf("%s\n",q+i);
    }
}
void swap(char *p,char *q)
{
    char *t;
    strcpy(t,q);
    strcpy(q,p);
    strcpy(p,t);
}

发布了45 篇原创文章 · 获赞 7 · 访问量 1594

猜你喜欢

转载自blog.csdn.net/qq_38173631/article/details/104028695