鱼C论坛

 找回密码
 立即注册
查看: 1403|回复: 4

[已解决]pta作业求助

[复制链接]
发表于 2021-4-16 21:03:08 From FishC Mobile | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
老师留的题目,没有头绪
最佳答案
2021-4-16 21:12:56
本帖最后由 肖-肖 于 2021-4-16 21:15 编辑

解释全再注释里,挺详细的

  1. #include <stdio.h>
  2. #include<string.h>
  3. void fun (char *str1,char *str2);

  4. int main()
  5. {
  6.     //也就是str1是你输入的原字符串,而str2是经过修改之后的字符串,先弄明白这个
  7.     char str1[20],str2[20];
  8.     scanf("%s",str1);
  9.     fun(str1,str2);
  10.     printf("%s",str2);

  11.     return 0;
  12. }
  13. void fun (char *str1,char *str2)
  14. {
  15.     //也就是要判断str1这个数组的长度
  16.     int len=0;//因为规定输入偶数个,所以不要担心除2不能整除的问题
  17.     while(str1[len]!='\0')
  18.     {
  19.         len++;//自认为有点6
  20.         //str1++;//指向下一个
  21.     }
  22.     int zj=len/2;
  23.     int jh;//用于交换位置
  24.     //下边就可以进行比较了
  25.     for(int i=0;i<zj;i++)
  26.     {
  27.         if(str1[i] < str1[i+zj])
  28.         {
  29.             /*jh=*str1[i];
  30.             *str1[i]=*str1[i+zj];
  31.             *str1[i+zj]=jh;//不对这样写是实现str1内部转换*/
  32.             str2[i]=str1[i+zj];//把大的给前面
  33.             str2[zj+i]=str1[i];//把小的给后边
  34.         }else{
  35.             str2[i]=str1[i];
  36.             str2[zj+i]=str1[i+zj];
  37.         }
  38.     }
  39.     //别忘了加'\0'不然后边会乱
  40.     str2[len]='\0';
  41. }
复制代码

下边是运行结果
ls57.png
Screenshot_2021-04-16-21-01-39-953_com.quark.browser.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-4-16 21:12:29 From FishC Mobile | 显示全部楼层
https://fishc.com.cn/forum.php?mod=viewthread&tid=194575&mobile=2
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-16 21:12:56 | 显示全部楼层    本楼为最佳答案   
本帖最后由 肖-肖 于 2021-4-16 21:15 编辑

解释全再注释里,挺详细的

  1. #include <stdio.h>
  2. #include<string.h>
  3. void fun (char *str1,char *str2);

  4. int main()
  5. {
  6.     //也就是str1是你输入的原字符串,而str2是经过修改之后的字符串,先弄明白这个
  7.     char str1[20],str2[20];
  8.     scanf("%s",str1);
  9.     fun(str1,str2);
  10.     printf("%s",str2);

  11.     return 0;
  12. }
  13. void fun (char *str1,char *str2)
  14. {
  15.     //也就是要判断str1这个数组的长度
  16.     int len=0;//因为规定输入偶数个,所以不要担心除2不能整除的问题
  17.     while(str1[len]!='\0')
  18.     {
  19.         len++;//自认为有点6
  20.         //str1++;//指向下一个
  21.     }
  22.     int zj=len/2;
  23.     int jh;//用于交换位置
  24.     //下边就可以进行比较了
  25.     for(int i=0;i<zj;i++)
  26.     {
  27.         if(str1[i] < str1[i+zj])
  28.         {
  29.             /*jh=*str1[i];
  30.             *str1[i]=*str1[i+zj];
  31.             *str1[i+zj]=jh;//不对这样写是实现str1内部转换*/
  32.             str2[i]=str1[i+zj];//把大的给前面
  33.             str2[zj+i]=str1[i];//把小的给后边
  34.         }else{
  35.             str2[i]=str1[i];
  36.             str2[zj+i]=str1[i+zj];
  37.         }
  38.     }
  39.     //别忘了加'\0'不然后边会乱
  40.     str2[len]='\0';
  41. }
复制代码

下边是运行结果
ls57.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-4-17 10:09:45 From FishC Mobile | 显示全部楼层
谢谢了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 13:51:56 | 显示全部楼层

不客气
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 03:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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