华为机试- 4 字符串分割

字符串分隔

http://www.nowcoder.com/questionTerminal/d9162298cb5a437aad722fccccaae8a7

题目描述

•连续输入字符串,请按长度为8拆分每个字符串后输出到新的字符串数组;
•长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。

输入描述:

连续输入字符串(输入2次,每个字符串长度小于100)

输出描述:

输出到长度为8的新字符串数组

示例1
输入

abc
123456789

输出

abc00000
12345678
90000000

解题思路

1 输入输出处理分析

题目明确说明是2组case.每次处理相同,所以我们使用了一个2次的循环。

2 边界条件处理

  1. 先考虑长度小于等于8的情况,先打印输出len个字符。
  2. 计算需要的填充数,并打印输出填充

3 长度大于8情况处理

1 循环打印输出所有字符
2 当长度为8的倍数时(j+1)%8 == 0,输出换行。
3 计算最后一个需要填充的数量,并打印输出填充

4 c语言实现

#include <stdio.h>
#include <string.h>

int main()
{
    int n=2;
    char str[100];
        for (int i=0; i < n; i++) {
            scanf("%s",str);
            int len = strlen(str);
            if (len/8 == 0 || len ==8) { //长度小于等于8
                for (int j = 0; j < len; j++) {
                    printf("%c",str[j]);
                }
                int padNum = 7- (len-1)%8;
                for (int j=0; j< padNum; j++) {
                    printf("0");
                }
                printf("\n");
            }
            else if(len/8 > 0) //长度大于8
            {
                for (int j=0; j<len; j++) {
                    printf("%c",str[j]);
                    if ((j+1)%8 == 0) {
                        printf("\n");
                    }
                }
                int lastPadNum = 7 - (len -1)%8;//最后一个填充处理
                for (int j=0; j<lastPadNum; j++) {
                    printf("0");
                }
                if (len%8 != 0) {
                    printf("\n");
                }

            }
        }
    return 0;
}
全部评论

相关推荐

4 7 评论
分享
牛客网
牛客企业服务