问题
来源:互联网 发布:算法的复杂性分为 编辑:程序博客网 时间:2024/05/20 15:10
//3. (****)有一段文本,将文本中的所有单词,存放到一个字符串数组中。 (要求占用内存最少)
char *array ="There are 5 sb in my class, one of them is yy!";//定义一个字符串数组,写一段文本
printf("%s\n", array);//打印数组测试后面结果
char *temp = array;//定义一个指针用来后面的循环遍历操作
int sum1 =0;//定义两个累加器 sum1为array的长度
int sum2 =0;//sum2为dest的长度
//循环得出array长度
while (*temp != '\0') {
sum1++;
temp++;
}
printf("%d\n", sum1);
temp = array;
//循环得出dest长度
while (*temp != '\0') {
if (((*temp >= 'A') && (*temp <='Z')) || ((*temp >= 'a') && (*temp <= 'z'))) {
sum2++;
}
temp++;
}
printf("%d\n", sum2);
//定义一个dest字符串数组存储所有单词
int sum3 = 0;//j为dest的下标
temp = array;
while (*temp != '\0') {
if (((*temp < 'A') || ((*temp >'Z') && (*temp < 'a')) || (*temp >'z')) && (((*(temp + 1) >= 'A') && (*(temp + 1) <= 'Z')) || ((*(temp + 1) >= 'a') && (*(temp + 1) <= 'z')))) {
sum3++;
}
temp++;
}
int sum4 = sum3 + 1;
printf("%d\n", sum4);
sum3 =0;
int sum5 = 0;
char **dest = malloc(sizeof(char) * sum2 + sum4);
for (int i =0; i < sum1; i++) {
if (((array[i] < 'A') || ((array[i] >'Z') && (array[i] < 'a')) || (array[i] > 'z')) && (((array[i +1] >= 'A') && (array[i +1] <= 'Z')) || ((array[i +1] >= 'a') && (array[i +1] <= 'z')))) {
sum3++;
sum5 =0;
}elseif((((array[i] >= 'A') && (array[i] <= 'Z')) || ((array[i] >='a') && (array[i] <= 'z')))){
dest[sum3][sum5] = array[i];
sum5++;
}
}
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题
- 问题???
- 问题
- 问题
- UIPageControl分页控件和 UIAlertView提示框
- 在c++中用while(cin)的问题
- 第9周项目——穷举法之年龄几何
- 数组和链表的区别以及数组和结构体的区别
- 第九周项目1-利用循环求和
- 问题
- NYOJ 68 三点顺序
- 计算机中文核心期刊和核心期刊影响因子
- Latex中如何放两列算法在框架中
- dll中调用对话框,出现Debug Assertion Failed!停在 ENSURE(this != NULL)
- UISwitch打开,关闭按钮
- 第九周 项目五 程序补充题1
- 问题1
- TCP/IP协议 HTTP协议