PTA输出字符串s从第m个字符开始的长度为l的子串

 

字符串输入输出练习

输入起始位置m、长度l及字符串s,要求输出字符串s从第m个字符开始的长度为l的子串。

输入格式:

测试数据有多组,处理到文件尾。 每组测试数据输入一行,首先是以一个空格间隔的两个整数m、l,分别表示起始位置和长度,然后在一个空格之后是一个字符串s(长度不超过80,可能包含空格)。测试数据保证取得的结果字符串至少包含一个字符。

输出格式:

对于每组测试,输出字符串s从第m个字符开始的长度为l的子串(若长度不足l,则只需输出从第m个字符开始到最后一个字符结束的子串)。每两组测试数据之间留一个空行。

#include<stdio.h>
int main()
{
    int m,l;
    char s[80][80];
    char ss[80][80];
  
    int i,j=0;

    //测试数据有多组,处理到文件尾。 每组测试数据输入一行,用二维数组存放多个字符串。
    while(scanf("%d %d",&m,&l)!=EOF&&l>=0)
    {
        
            gets(s[j]);
            for(i=m;i<m+l;i++)
            {
               ss[j][i-m]=s[j][i];
            }
            ss[j][l]='\0';
//在获取到的字符串末尾加上\0,无论是否复制完s[j]字符串都可以作为结束的标志
//(也就是说如果遇到s[j]字符串原本的\0,就会结束输出,不在考虑我们后面添加的\0)
            j++;
    }
    
    for(i=0;i<j;i++)
    {
        puts(ss[i]);
        if(i!=j-1)
        {
            printf("\n");
        }
    }
}

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序和三三总有一个能跑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值