鱼C论坛

 找回密码
 立即注册
查看: 1398|回复: 7

[已解决]字符串切分合并

[复制链接]
发表于 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]
最佳答案
2021-4-15 13:20:13
给出了模板就简单不少了啊!
我写的代码如下:<注释中有我思考的过程,自认为特别详细了!!!>
#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';
}
运行结果如下:
ls52.png
OK 希望对你有帮助吧!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-4-15 13:20:13 | 显示全部楼层    本楼为最佳答案   
给出了模板就简单不少了啊!
我写的代码如下:<注释中有我思考的过程,自认为特别详细了!!!>
#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';
}
运行结果如下:
ls52.png
OK 希望对你有帮助吧!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-15 13:31:39 | 显示全部楼层
本帖最后由 wp231957 于 2021-4-15 13:33 编辑
肖-肖 发表于 2021-4-15 13:20
给出了模板就简单不少了啊!
我写的代码如下:


我就觉得  你的代码存在问题,于是测试了一下,果不其然

乱码 论坛发不出来  贴个图吧
无标题.jpg
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-15 13:35:17 | 显示全部楼层
本帖最后由 肖-肖 于 2021-4-15 13:40 编辑
wp231957 发表于 2021-4-15 13:31
我就觉得  你的代码存在问题,于是测试了一下,果不其然

乱码 论坛发不出来  贴个图吧


嗯 欢迎指出,我改下试试
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-15 13:39:10 | 显示全部楼层
肖-肖 发表于 2021-4-15 13:35
嗯 对对对,欢迎指出,相等的情况我没弄,我改下试试

不是差在相等,看好题目,比较两个子串的大小
子串的大小咋比较   
如果第一个字符码值大的大,如果相等 看第二个码值 如果还相等  看第三个。。。。。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-15 13:52:51 | 显示全部楼层
本帖最后由 肖-肖 于 2021-4-15 13:54 编辑
wp231957 发表于 2021-4-15 13:39
不是差在相等,看好题目,比较两个子串的大小
子串的大小咋比较   
如果第一个字符码值大的大,如果相 ...

嗯 我改好了,刚才我这断网了,我弄出来了还发布不出去,有点着急啊!哈哈
效果图如下:
ls54.png
代码如下:
#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];//把小的给后边
        }else{
            str2[i]=str1[i];
            str2[zj+i]=str1[i+zj];
        }
    }
    //别忘了加'\0'不然后边会乱
    str2[len]='\0';
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-4-15 13:58:15 From FishC Mobile | 显示全部楼层
谢谢v
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-15 14:01:58 | 显示全部楼层

不客气 对你有帮助就行
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-13 16:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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