fdsf 发表于 2018-4-20 17:45:46

排序交换内存块

#include <stdio.h>
#include <string.h>


void sort (char **p,int num)
{
        int i,j;
        //char *temp = NULL;
        char temp01 ;
        for (i = 0;i < num;i++)
        {
                for (j = i;j < num;j++)
                {
                        if (strcmp (p,p ) > 0)
                        {
                                /*
                                temp = p ;
                                p = p ;
                                p = temp;
                                */
                                strcpy (temp01,p);       //这边为什么会出错?
                                strcpy (p ,p);
                                strcpy (p,temp01);
                        }
                }
        }
}

void print_sort (char **mystring,int num)
{
        int i;
        for (i = 0;i < num;i++)
        {
                printf ("%s\n",*(mystring + i));
        }
}
int main ()
{
        int i;
        char *mystring [] = {"age","13thr","thr"};
        int num = sizeof (mystring) / sizeof (mystring );
        sort (mystring,num);
        print_sort (mystring,num);
        return 0;
}


请问这是怎么回事?谢谢各位!!!

ba21 发表于 2018-4-20 21:16:44

//这边为什么会出错? 是知道为什么出错。
不知道你是要干嘛,能把你要实现的功能说下?

fdsf 发表于 2018-4-21 12:40:41

ba21 发表于 2018-4-20 21:16
//这边为什么会出错? 是知道为什么出错。
不知道你是要干嘛,能把你要实现的功能说下?

只是实现简单的交换,注释部分可以让指针数组里的元素排序(改变指针指向),出错的地方我想交换指针所指的内存块进行排序。

ba21 发表于 2018-4-21 19:02:10

本帖最后由 ba21 于 2018-4-21 19:05 编辑

fdsf 发表于 2018-4-21 12:40
只是实现简单的交换,注释部分可以让指针数组里的元素排序(改变指针指向),出错的地方我想交换指针所指 ...

你直接说数组排序别人不就理解了。

//char *temp = NULL;
   /*
                              temp = p ;
                              p = p ;
                              p = temp;
                              */
这注释掉的部份不就实现了功能。

1,首先不说strcpy多此一举。
2,字符串的长度都不一样。"age","13thr","thr"长度一样吗?
3, char *mystring [] = {"age","13thr","thr"}; 这3个字符串肯定在一个连续的内存块中。

下面测试代码。自己去找原因吧:
void sort (char *p[],int num) 这个地方我也改了下,不影响,我只是觉得你**难理解。 指针数组,形参你不认为用 char *p[] 人家好理解些

#include <stdio.h>
#include <string.h>


void sort (char *p[],int num)
{
      int i,j;
      //char *temp = NULL;
      char temp01;

               strcpy (temp01,p);       //这边为什么会出错?

               printf("%s\n\n", temp01);

}

void print_sort (char **mystring,int num)
{
      int i;
      for (i = 0;i < num;i++)
      {
                printf ("%s\n",*(mystring + i));
      }
}
int main ()
{
      int i;
      char *mystring[] = {"age","13thr","thr"};
      int num = sizeof (mystring) / sizeof (mystring );

      sort (mystring,num);
      print_sort (mystring,num);
      return 0;
}
页: [1]
查看完整版本: 排序交换内存块