华为机试- 4 字符串分割
字符串分隔
http://www.nowcoder.com/questionTerminal/d9162298cb5a437aad722fccccaae8a7
题目描述
•连续输入字符串,请按长度为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;
}