‘壹’ 用c语言,翻转字符串,(例如输入“ABCD”,则输出“DCBA”)!方法越多越好!!
【方法一】
//也是最简单的有点投机
#include <stdio.h>
int main(){
 char str[]="ABCD";
 int i;
 for(i=3;i>=0;i--) printf("%c",str[i]);
 return 0;
}
【方法二】
/*
   用指针的,将第一个与最后一个互换,第二个与倒数第二个互换……直到逆置完成
*/
#include <stdio.h>
#include <string.h>
int main(){
 char str[]="ABCD",*start,*end,t;
 int len,i;   
 len=strlen(str);
 start=str;
 end=&str[len-1];
 while(start<end){
     t=*start;
     *start=*end;
     *end=t;
     start++;
     end--;
 }
 printf("REVERSED:\n");
 for(i=0;str[i];i++) printf("%c",str[i]);
 return 0;
}
【方法三】
//用堆栈的性质来实现
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAXSTACK 100
char pop(struct stack *stk);
void push(char ch,struct stack *stk);
int empty(struct stack *stk);
struct stack{
 int top;
 char str[MAXSTACK];
};
int main(void)
{
 int i,len_str;
 char str[MAXSTACK];
 struct stack s;
 s.top=-1;
 printf("\nInput the string please:");/*输入你要逆置的字符串e.g.“ABCD”*/
 gets(str);
 len_str=strlen(str);
 for(i=0;i<len_str;i++)
     push(str[i],&s);
 printf("The disorder is:");
 for(i=0;i<len_str;i++){
    if(!empty(&s))
    printf("%c",pop(&s));
 }
 getch();
 return 0;
}
char pop(struct stack *stk){
 return stk->str[stk->top--];
}
void push(char ch,struct stack *stk){
 if(stk->top==MAXSTACK-1){
    printf("\nOVERFLOW!\n");
    exit(1);
 }
 else stk->str[++(stk->top)]=ch;
    return;
}
int empty(struct stack *stk){
 return (stk->top==-1);
}
还可以用递归的思想来解决该问题,这里就不多说了……
‘贰’ C语言 把字符串前后倒置
这样改就好了:
voidfun(char*s)
{
inti,j=0,n;
chart[100];//t不要和s指向同一个字符串,不然后面的赋值操作有点乱套。
n=strlen(s);
for(i=n-1;i>=0;i--)//i==0的时候也要复制过去。
t[j++]=s[i];
for(i=0;i<n;i++)
s[i]=t[i];
s[++i]='
