当前位置: 代码迷 >> C语言 >> 头痛的问题.指针
  详细解决方案

头痛的问题.指针

热度:493   发布时间:2008-01-03 12:43:28.0
头痛的问题.指针
问一问题.定义一个字符数组如 a[40],和一个指针*p[2].是不是可能放两个字符串在a[40]里面如  "how" "are".然后用p[1],p[2]分别指向两个字符串,进行运行.


#include<stdio.h>
#include<string.h>
#define n 3
void main()
{
int i;
char *p[3],q[20];
for(i=0;i<n;i++)
{p[i]=(char*)malloc(40);  这里的强制转换,是不是相当
gets(*p); }               于定义了一个a[3][40]的字符数组.
for(i=0;i<n;i++)
{
if(strcmp(p[i],p[i+1])<0)
{strcpy(q,p[i]);strcpy(p[i],p[i+1]);strcpy(p[i+1],q); }
}
for(i=0;i<n;i++)
puts(p[i]);
}

....................................................................

上面可不可发改成下面的,这个又是什么地方不正确,让各位高手指点一下.#include<stdio.h>
#include<string.h>
void main()
{
void name(char *a[]);
char *p[3],a[3][20];
int i,t;
for(i=0;i<3;i++)
gets(a[i]);
name(a[i]);
for(t=0;t<3;t++)
puts(*a[i]);
}
void *name(char a[])
{
int i;
char *p;
for(i=1;i<3;i++)
  if(strcmp(*a[i],*a[i+1])<0)   
{p=a[1];a[1]=a[i+1];a[i+1]=p;}
}
搜索更多相关的解决方案: 指针  头痛  

----------------解决方案--------------------------------------------------------
不知道你那个name()是干什么用的,排序吗 ,为什么下标从1开始
单从语法上给你改一下:
#include<string.h>
void main()
{
void name(char *a[]);
char *p[3],a[3][20]; /* p是指针数组,a是二维数组 */
int i,t;
for(i=0;i<3;i++)
gets(a[i]);
name(a);
for(t=0;t<3;t++)
puts(a[i]);
}
void *name(char a[][20])
{
int i;
char *p;
for(i=1;i<3;i++)
  if(strcmp(a[i],a[i+1])<0)   
{p=a[1];a[1]=a[i+1];a[i+1]=p;}
}
----------------解决方案--------------------------------------------------------
不可以,你可以用二维数组来实现,因为你这里是一个字符数组。
如果是一个字符指针数组就可以,里面的每个元素存放一个字符“串”的地址。

[[italic] 本帖最后由 随心 于 2008-1-3 14:31 编辑 [/italic]]
----------------解决方案--------------------------------------------------------
那这部分错在那里?
可不可以在此调整指针数组中.指针的指向.
void *name(char a[])
{
int i;
char *p;
for(i=1;i<3;i++)
  if(strcmp(*a[i],*a[i+1])<0)   
{p=a[1];a[1]=a[i+1];a[i+1]=p;}
}
----------------解决方案--------------------------------------------------------
是这样的

void name(char *a[])
{
int i;
char *p;
for(i=1;i<3;i++)
  if(strcmp(*a[i],*a[i+1])<0)   
{p=a[1];a[1]=a[i+1];a[i+1]=p;}
}
----------------解决方案--------------------------------------------------------

----------------解决方案--------------------------------------------------------
  相关解决方案