
关于C语言的指针问题,求助
例8.27将若干字符串按字母顺序(由小到大)输出。#include<stdio.h>#include<string.h>intmain(){voidsort(char*n...
例8.27 将若干字符串按字母顺序(由小到大)输出。
#include <stdio.h>
#include <string.h>
int main()
{void sort(char *name[ ],int n);
void print(char *name[ ],int n);
char *name[ ]={"Follow","Great", "FORTRAN","Computer"};
int n=4;
sort(name,n);
print(name,n);
return 0;
}
void sort(char *name[ ],int n)
{char *temp; int i,j,k;
for (i=0;i<n-1;i++)
{ k=i;
for (j=i+1;j<n;j++)
if(strcmp(name[k],name[j])>0) k=j;
if (k!=i)
{ temp=name[i]; name[i]=name[k];
name[k]=temp;
}
}
}
void print(char *name[ ],int n)
{ int i;
for(i=0;i<n;i++)
printf("%s\n",name[i]);
}
(1)我不明白为什么是strcmp(name[k],name[j]),这应该变成了比较地址啊,而不是strcmp(*name[k],*name[j])呢??
(2)还有,temp=name[i]; name[i]=name[k];这不是不行的吗?就像
#include <stdio.h>
int main()
{void swap(int *p1,int *p2);
int a,b; int*pointer_1,*pointer_2;
scanf("%d,%d",&a,&b);
pointer_1=&a; pointer_2=&b;
if (a<b) swap(pointer_1,pointer_2);
printf("max=%d,min=%d\n",a,b);
return 0;
}
void swap(int *p1,int *p2)
{ int *p;
p=p1; p1=p2; p2=p;
}
这是不行的。
为什么那个temp=name[i]; name[i]=name[k];又行啊?? 展开
#include <stdio.h>
#include <string.h>
int main()
{void sort(char *name[ ],int n);
void print(char *name[ ],int n);
char *name[ ]={"Follow","Great", "FORTRAN","Computer"};
int n=4;
sort(name,n);
print(name,n);
return 0;
}
void sort(char *name[ ],int n)
{char *temp; int i,j,k;
for (i=0;i<n-1;i++)
{ k=i;
for (j=i+1;j<n;j++)
if(strcmp(name[k],name[j])>0) k=j;
if (k!=i)
{ temp=name[i]; name[i]=name[k];
name[k]=temp;
}
}
}
void print(char *name[ ],int n)
{ int i;
for(i=0;i<n;i++)
printf("%s\n",name[i]);
}
(1)我不明白为什么是strcmp(name[k],name[j]),这应该变成了比较地址啊,而不是strcmp(*name[k],*name[j])呢??
(2)还有,temp=name[i]; name[i]=name[k];这不是不行的吗?就像
#include <stdio.h>
int main()
{void swap(int *p1,int *p2);
int a,b; int*pointer_1,*pointer_2;
scanf("%d,%d",&a,&b);
pointer_1=&a; pointer_2=&b;
if (a<b) swap(pointer_1,pointer_2);
printf("max=%d,min=%d\n",a,b);
return 0;
}
void swap(int *p1,int *p2)
{ int *p;
p=p1; p1=p2; p2=p;
}
这是不行的。
为什么那个temp=name[i]; name[i]=name[k];又行啊?? 展开
3个回答
展开全部
(1)strcmp的原型是int strcmp( const char *string1, const char *string2 );其参数是传入两个要比较的字符串的地址。函数的实现部分肯定会用指针指向的内容作比较的。
(2)
void swap(int *p1,int *p2)
{ int *p;
p=p1; p1=p2; p2=p;
}这个函数确实不能实现交换,因为虽然参数是指针,但传给swap的参数其实是指针的拷贝,所以当退出swap函数后,p,p1,p2会退栈,也就是根本没有真正的交换两个数据。
而void sort(char *name[ ],int n) 有点意思,传进去的也是一个字符串的首地址拷贝,但是该函数内部对字符串地址偏移做了操作,也就是他改变了原指向字符串数组中字符串指针在数组中的排列顺序,有点绕人,举个例子吧,例如:
"Follow","Great", "FORTRAN","Computer"的地址在原始数组中的排列为0xe8,0x60,0x40,0xb8,当sort换过之后,对应的地址在数组中的排序变为了0xb8,0x40,0xe8,0x60,,
(2)
void swap(int *p1,int *p2)
{ int *p;
p=p1; p1=p2; p2=p;
}这个函数确实不能实现交换,因为虽然参数是指针,但传给swap的参数其实是指针的拷贝,所以当退出swap函数后,p,p1,p2会退栈,也就是根本没有真正的交换两个数据。
而void sort(char *name[ ],int n) 有点意思,传进去的也是一个字符串的首地址拷贝,但是该函数内部对字符串地址偏移做了操作,也就是他改变了原指向字符串数组中字符串指针在数组中的排列顺序,有点绕人,举个例子吧,例如:
"Follow","Great", "FORTRAN","Computer"的地址在原始数组中的排列为0xe8,0x60,0x40,0xb8,当sort换过之后,对应的地址在数组中的排序变为了0xb8,0x40,0xe8,0x60,,
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
字符串就用地址作为参数的,字符串比较也用地址做参数,并不是说比较地址,
地址只是作为参数
地址只是作为参数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
第二个可以改变值,swap()里写成
int p;
p=*p1;*p1=*p2;*p2=p;
这样可以完成值的交换
int p;
p=*p1;*p1=*p2;*p2=p;
这样可以完成值的交换
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询