现在实现的要求是实现输入字符串的逆向输出,比如我们输入的是abcdef,输出的就应该是fedcba,这其实很简单就可以实现了,我们我们把输入的字符串逆序存放到一个新建的字符串中,接着输出就可以了。
程序代码如下:
#include "stdio.h"
#include
void opp(char *s,char *p,int i )
{
while(i--)
{
*(s++)=*(p+i);
}
*s='\0';
}
void main()
{
char a[300];
char b[300];
int L;
gets(a);
L=strlen(a);
printf("the string is over\n");
opp(b,a,L);
puts(b);
}
其中子函数void opp(char *s,char *p,int i
),定义了两个字符串指针,在主函数中对应实例:opp(b,a,L);
分别为新开辟的空数组b和我们存放输入值的数组a,以及数组a的长度L,引用子函数,实参传入形参:
void opp(a,b,L )
{
while(L--)
{
*(b++)=*(a+L);
}
*s='\0';
}
第一个数为(数组a的首地址+数组的长度)所指向的数,比如数组a为abcde,那么*(a+L),因为在while(L--),这时L=4;故第一次*(b(0)=(*a(4));就是把数组a的e放入b数组的首地址,第二次把a中的d给b的第二个元素,以此类推:这样把a数组的元素逆序复制给b数组,最后千万不要忘记加上字符串结束标志‘\0’,如果不加,输出将出现乱码。