鱼C论坛

 找回密码
 立即注册
查看: 2218|回复: 2

[已解决]字符串逆序

[复制链接]
发表于 2021-10-28 17:00:50 | 显示全部楼层 |阅读模式
10鱼币

写一个递归算法来实现字符串逆序存储,要求不另设串存储空间。在turn函数中进行填写
  1. #include <iostream>
  2. #include<string.h>
  3. using namespace std;
  4. #define INITSTRLEN 100
  5. typedef struct
  6. { char *ch;
  7.   int length;
  8. int strsize;
  9. }String;
  10. void initString(String &s)
  11. { s.ch = new char[INITSTRLEN ]; /*初始化串存储空间*/
  12.   s.length = 0; /*初始化串长*/
  13.   s.strsize = INITSTRLEN; /*初始化当前存储空间容量*/
  14. }
  15. void turn(String &s,int &i)//算法填写
  16. {
  17.        
  18.        
  19.        
  20.        
  21.        

  22. }
  23. void list(String s)
  24. {
  25. printf("%s", s.ch);
  26. printf("\n");}
  27. int main(){
  28.   String s;int i=0;
  29.   initString(s);
  30.   printf("please input the string s:\n");
  31.   scanf("%s", s.ch);
  32.   s.length=strlen(s.ch);
  33.   
  34.   turn(s,i);
  35.   list(s);
  36.   delete(s.ch);
  37.   return 0;
  38.   }
复制代码
最佳答案
2021-10-28 17:00:51

最佳答案

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-10-28 17:00:51 | 显示全部楼层    本楼为最佳答案   
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-10-28 17:53:15 | 显示全部楼层

  1. #include <iostream>
  2. #include<string.h>
  3. using namespace std;
  4. #define INITSTRLEN 100
  5. typedef struct
  6. { char *ch;
  7.   int length;
  8. int strsize;
  9. }String;
  10. void initString(String &s)
  11. { s.ch = new char[INITSTRLEN ]; /*初始化串存储空间*/
  12.   s.length = 0; /*初始化串长*/
  13.   s.strsize = INITSTRLEN; /*初始化当前存储空间容量*/
  14. }
  15. void turn(String &s,int &i)//算法填写
  16. {
  17.         char temp = s.ch[i];
  18.         s.ch[i] = s.ch[s.length-i-1];
  19.         s.ch[s.length-1-i] = temp;
  20.         //cout<<s.ch[i]<<endl;
  21.         i++;
  22.         if(i<s.length/2)turn(s,i);
  23.        
  24.        

  25.        
  26.        

  27. }
  28. void list(String s)
  29. {
  30. printf("%s", s.ch);
  31. printf("\n");}
  32. int main(){
  33.   String s;int i=0;
  34.   initString(s);
  35.   printf("please input the string s:\n");
  36.   scanf("%s", s.ch);
  37.   s.length=strlen(s.ch);
  38.   
  39.   turn(s,i);
  40.   list(s);
  41.   delete(s.ch);
  42.   return 0;
  43.   }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-26 00:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表