C语言:写一函数,使输入的一个字符串按反序存放,在主函数中输入输出反序后的字符串.

 我来答
问明6E
高粉答主

2019-07-10 · 每个回答都超有意思的
知道答主
回答量:279
采纳率:100%
帮助的人:13.1万
展开全部

#include<stdio.h>

#include<string.h>//使用字符串函数时头文件 

int str(char a[20],char b[20])//定义两个字符型数组 

{

int i, j, k;

j=strlen(a);//测试字符串长度; 

i=0;

k=j-1;

while(i<j)

{

b[k]=a[i];//互换值; 

i++;

k--;

}

return 0;

}

int main()

{

char c[20];

char d[20];

int i,l;

//gets(c);//输入字符串;

scanf("%s",c); 

l=strlen(c);//测试字符串长度; 

str(c,d);//调用函数; 

for(i=0; i<l; i++)

{

printf("%c",d[i]);//输出数值; 

}printf("\n"); 

printf("%s",d);//直接输出字符串,此时输出的是字符数组名,而不是数组元素名; 

return 0;

}

运行效果:

扩展资料:

while语句若一直满足条件,则会不断的重复下去。但有时,需要停止循环,则可以用下面的三种方式:

一、在while语句中设定条件语句,条件不满足,则循环自动停止。

如:只输出3的倍数的循环;可以设置范围为:0到20。

二、在循环结构中加入流程控制语句,可以使用户退出循环。

1、break流程控制:强制中断该运行区内的语句,跳出该运行区,继续运行区域外的语句。

2、continue流程控制:也是中断循环内的运行操作,并且从头开始运行。

听不清啊
高粉答主

推荐于2018-02-27 · 说的都是干货,快来关注
知道顶级答主
回答量:7.8万
采纳率:89%
帮助的人:1.9亿
展开全部

reverse(char s[])

{

 int i=0,j;

 char c;

 j=strlen(s)-1;

 while(i<j)

 {c=s[i];s[i++]=s[j];s[j--]=c;}

}

main()

{

 char s[200];

 gets(s);

 reverse(s);

 puts(s);

}

本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2013-11-29
展开全部
/*字符串转置*/
#include<stdio.h>
void main()
{
void revStr(char *);
char str[80];
printf("输入一个字符串: ");
gets(str);
revStr(str);
printf("转置后的字符串: %s\n",str);
}
void revStr(char *str)
{
int i,len;
char tmp;
for(len=0;str[len];len++);
for(i=0;i<len/2;i++)
{
tmp=str[len-i-1];
str[len-i-1]=str[i];
str[i]=tmp;
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
风若远去何人留
2013-11-29 · 知道合伙人互联网行家
风若远去何人留
知道合伙人互联网行家
采纳数:20412 获赞数:450135
专业C/C++软件开发

向TA提问 私信TA
展开全部
#include <stdio.h>
void Reverse_string(char *str)
{
int len = strlen(str), i;
char t;
for(i = 0; i <= len / 2; i ++)
{
t = str[i];
str[i] = str[len - i - 1];
str[len - i - 1] = t;
}
}

int main()
{
char buffer[100];
gets(buffer);
Reverse_string(buffer);
printf("%s\n", buffer);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
CzO茝
2013-11-29
知道答主
回答量:3
采纳率:0%
帮助的人:4103
展开全部
我这里有种很新颖的方式,采用函数递归调用,求采纳。

#include<stdio.h>
int main()
{
void reverse(char s[]);
char s[80];
scanf("%s",s);
reverse(s);
return 0;
}
void reverse(char s[])
{
int i=0;
if(s[i]!='\0')
{
i++;
reverse(&s[i]); //这里采用递归,若你学了指针表示起来方便一点
printf("%c",s[i-1]);
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式