C语言利用指针法实现20以内的字符串倒置.
#include<stdio.h>#include<string.h>intmain(){char*a[20],i,c,temp;printf("Enteralphabe...
#include<stdio.h>
#include<string.h>
int main()
{
char *a[20],i,c,temp;
printf("Enter alphabet string a:\n");
scanf("%s",a);
c=strlen(a)-1;
printf("%s",&a);
for(i=0;i<strlen(a)/2;i++)
{
temp=*a[strlen(a)-i-1];
*a[strlen(a)-i-1]=*a[i];
*a[i]=temp;
}
printf("\nNow alphabet string a:\n");
printf("%s",&a);
printf("\n");
return 0;
} 展开
#include<string.h>
int main()
{
char *a[20],i,c,temp;
printf("Enter alphabet string a:\n");
scanf("%s",a);
c=strlen(a)-1;
printf("%s",&a);
for(i=0;i<strlen(a)/2;i++)
{
temp=*a[strlen(a)-i-1];
*a[strlen(a)-i-1]=*a[i];
*a[i]=temp;
}
printf("\nNow alphabet string a:\n");
printf("%s",&a);
printf("\n");
return 0;
} 展开
展开全部
#include<stdio.h>
#include<string.h>
int main()
{
char a[20],i,c,temp,j; //定义字符数组,不需加*,否则都成字符指针数组了。
printf("Enter alphabet string a:\n");
scanf("%s",a);
c=strlen(a)-1;//这里找到最后一个字符的下标
printf("%s",a);//输出字符串,变量列表直径用字符数组名即可,不能用求地址&,下同
for(i=0,j=c;i<j;i++,j--)//这里循环条件做了调整,i、j分别为字符串首末的下标
{
temp=*(a+j); //*(a+j)相当于a[j]
*(a+j)=*(a+i);//*(a+i)相当于a[i]
*(a+i)=temp;
}
printf("\nNow alphabet string a:\n");
printf("%s",a);
printf("\n");
return 0;
}
在你原来的代码基础上修改的。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询