|
发表于 2021-4-15 12:49:05
From FishC Mobile
|
显示全部楼层
|阅读模式
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x

输入一个字符串(串长为偶数),从中点切分成前后两个子串,比较大小,合并成一个新串,大串在前小串在后
函数接口定义
【void fun ( char *str1,char *str2);】
裁判测试程序样例
【#include <stdio.h>
#include<string.h>
void fun ( char *str1,char *str2);
int main()
{char str1[20],str2[20];
scanf("%s",str1);
fun(str1,str2);
printf("%s",str2);
return 0;
}
】
输入
【abcdefgh】
输出
【efghabcd】
[代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB]
给出了模板就简单不少了啊!
我写的代码如下:<注释中有我思考的过程,自认为特别详细了!!!>
- #include <stdio.h>
- #include<string.h>
- void fun (char *str1,char *str2);
- int main()
- {
- //也就是str1是你输入的原字符串,而str2是经过修改之后的字符串,先弄明白这个
- char str1[20],str2[20];
- scanf("%s",str1);
- fun(str1,str2);
- printf("%s",str2);
- return 0;
- }
- void fun (char *str1,char *str2)
- {
- //也就是要判断str1这个数组的长度
- int len=0;//因为规定输入偶数个,所以不要担心除2不能整除的问题
- while(str1[len]!='\0')
- {
- len++;//自认为有点6
- //str1++;//指向下一个
- }
- int zj=len/2;
- int jh;//用于交换位置
- //下边就可以进行比较了
- for(int i=0;i<zj;i++)
- {
- if(str1[i] < str1[i+zj])
- {
- /*jh=*str1[i];
- *str1[i]=*str1[i+zj];
- *str1[i+zj]=jh;//不对这样写是实现str1内部转换*/
- str2[i]=str1[i+zj];//把大的给前面
- str2[zj+i]=str1[i];//把小的给后边
- }
- }
- //别忘了加'\0'不然后边会乱
- str2[len]='\0';
- }
复制代码
运行结果如下:
OK 希望对你有帮助吧!
|
|