题目描述
•连续输入字符串,请按长度为8拆分每个字符串后输出到新的字符串数组;
•长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
输入描述:
连续输入字符串(输入2次,每个字符串长度小于100)
输出描述:
输出到长度为8的新字符串数组
示例1
输入
abc 123456789
输出
abc00000 12345678 90000000
解题思路
1 输入输出处理分析
题目明确说明是2组case.每次处理相同,所以我们使用了一个2次的循环。
2 边界条件处理
- 先考虑长度小于等于8的情况,先打印输出len个字符。
- 计算需要的填充数,并打印输出填充
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; }