字符串分割--CAN通信

本文介绍了一种简单的字符串处理算法,该算法将输入的字符串按长度为8进行拆分,并对不足长度的部分用数字0填充。通过示例展示了如何使用C语言实现这一功能,包括字符串读取、长度计算、循环拆分及输出。

题目描述
•连续输入字符串,请按长度为8拆分每个字符串后输出到新的字符串数组;
•长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
输入描述:
连续输入字符串(输入2次,每个字符串长度小于100)
输出描述:
输出到长度为8的新字符串数组

示例1
输入
abc
123456789
输出
abc00000
12345678
90000000

算是比较简单的一道了,直接拆分为8的小段,超过len的部分就替换成0就可以了,
工作中倒是碰到过这种算法,比如CAN通讯的时候。
#include<stdio.h>
#include<string.h>

int main()
{
    char arr1[100] = {0};
    char arr2[100] = {0};
    memset(arr1, 0, 100);
    memset(arr2, 0, 100);
    gets(arr1);
    gets(arr2);
    //printf("%s\n", arr1);
    //printf("%s\n", arr2);
    int len1 = strlen(arr1);
    int len2 = strlen(arr2);
    int count1 = (len1 + 7) / 8;
    int count2 = (len2 + 7) / 8;
    int i, j;
    for(i = 0; i < count1; i++)
    {
        for(j = 0; j < 8; j++)
        {
            if((8 * i) + j < len1)
            {
                printf("%c", arr1[(8 * i) + j]);
            }
            else
            {
                printf("0");
            }
        }
        printf("\n");
    }
    for(i = 0; i < count2; i++)
    {
        for(j = 0; j < 8; j++)
        {
            if((8 * i) + j < len2)
            {
                printf("%c", arr2[(8 * i) + j]);
            }
            else
            {
                printf("0");
            }
        }
        printf("\n");
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值