问题描述
- 指针数组两种排序方法结果大相径庭,求大神指导
-
#include
#include
int main()
{
void rankArr(char *pr[]);
char *p[]={"china","japan","tokyo","pairs","narry"};int i;
for(i=0;i
printf("%sn",p[i]);
rankArr(p);
for(i=0;i
printf("%sn",p[i]);
return 0;
}
void rankArr(char *pr[])
{
char *temp;
int i , j ;
for(i=0;i
{
for(j=i+1;j
{
if(strcmp(pr[i],pr[j])>0);
{
temp=pr[j];
pr[j]=pr[i];
pr[i]=temp;
}
}
}
}/*void rankArr(char pr[])
{
char *temp;//定义交换时存储临时变量的字符串单元
int i, j;
for( i=0;i
{
for( j=0;j
{
if(strcmp(pr[j],pr[j+1])>0)
{
temp=pr[j+1];
pr[j+1]=pr[j];
pr[j]=temp;
}//调用内置函数完成交换字符串
}
}
}/
解决方案
if(strcmp(pr[i],pr[j])>0);
这里多了一个逗号,导致后面的交换不在判断中,而是每次都执行。
解决方案二:
点击发表框工具栏上面的代码片图标,把代码放到代码片里,否则粘贴过来,容易出现错误,格式也很乱。
解决方案三:
注意循环体中指针数组下标是否有越界。
解决方案四:
而且你的代码有不止一个错误。根本不是什么大相径庭,而是错误百出。
解决方案五:
你想在函数中改变指针的值,则函数的参数必须是指向指针的指针。
就像你想使用 int 型变量的值,函数的参数必须是指向 int 的指针。