从字符串中删除空格
我试图从程序中删除字符串中的空格。 有人可以给我手?从字符串中删除空格
int main()
{
char str[15];
int i=0;
gets(str);
while(str[i] !=0){
if(str[i] == 32)
{
str[i++] = str[i];
str[i] = str[i++];
}
}
str[strlen(i)] = '\0';
printf("%s", str);
return 0;
}
THX
你可以使用2个三分球。我不熟悉C,所以我想检查str [i] == 0意味着字符串的结尾。
int main()
{
char str[15];
int i=0;
int j=0;
gets(str);
while(str[i] !=0 && str[j] !=0){
while(str[j] == 32)
{
j++;
}
if (str[j] ==0){
break;
}
str[i] = str[j];
i++;
}
str[strlen(i)] = '\0';
printf("%s", str);
return 0;
}
是的,当'gets'创建的字符串没有溢出你给它的缓冲区时终止为0(空)。 – 2011-03-31 14:45:33
那么因为您使用C修剪不是一个选项。 首先,你对这条线有什么看法: str [i] = str [i ++]; ? 这与i ++的 基本相同;
我们的代码:
char *mystring, *read, *write;
// mystring gehts filled with a null terminated string here
read = mystring;
write = mystring;
while(*read != '\0') {
if(*read == ' ')
read++;
else
*write++ = *read++;
}
*write = '\0';
如果你喜欢写另一个字符串,只要写点到您希望它是位置。不要忘记检查你有足够的空间;)
你打算在这种条件下发生什么?
if(str[i] == 32)
{
str[i++] = str[i];
str[i] = str[i++];
}
实际发生了什么? (提示:重新读取部上我++)
- 皮特
几个问题:
永远永远永远永远永远永远使用
gets
。首先,它从C99开始不再使用,并且将从标准的下一版本中消失。其次,它将在你的代码中引入了一个故障点(不是可能是介绍,会介绍)。改为使用fgets(str, sizeof str, stdin)
代替gets(str)
。-
使用字符常量,而不是数值,因为所有的世界不是ASCII:
if (str[i] == ' ') // not str[i] == 32
空白包括标签,换页,返回等,而不仅仅是空间;而不是检查单个值,请使用库函数
isspace()
。-
以下行是一个问题:
str[i++] = str[i]; str[i] = str[i++];
你传递一个整数值到
strlen
:这是行不通的。它会将该整数值解释为一个地址(至少应该得到一个警告),结果可能不好。
您可以在一个循环有两个数组索引做到这一点:
#include <stdio.h>
#include <ctype.h>
int main(void)
{
char str[15];
if (fgets(str, sizeof str, stdin) != NULL)
{
size_t r, w;
printf("Original: \"%s\"\n", str);
/**
* str[r] is the element that we are reading; str[w]
* is the element that we are writing
*/
for (r = 0, w = 0; str[r] != 0; r++)
{
if (!isspace(str[r])) // if str[r] is not a whitespace character
str[w++] = str[r]; // write it to str[w]; note that we only
// advance w for non-whitespace chars
}
str[w] = 0; // add the 0 terminator at the end
printf("Stripped: \"%s\"\n", str);
}
return 0;
}
显然,这改变了原来的字符串。如果由于某种原因需要保留原始输入,则必须声明第二个缓冲区来保存修改过的字符串。
此代码是速度快,工作正常..希望这有助于为UR情况下..复制并粘贴到一个文件,并测试它..
#include <stdio.h>
main()
{
char str[100];
int len = 0;
gets(str);
len = strlen(str);
int i = 0;
while(str[i]!='\0')
{
if(str[i] == ' ')
{
memcpy(&str[i], &str[i+1], len - i);
len--;
}
i++;
}
str[len] = '\0';
printf("O/P : %s\n",str);
}
这工作得很好..
哪些您发布的当前代码的缺点? – 2011-03-31 14:35:34
它没有工作。 str [strlen(i)] ='\ 0';将str [strlen(str)] ='\ 0'; – yEL155 2011-03-31 14:37:29
作业?没问题,如果是这样,只需用标记标记,以便得到更好的答案 – pmg 2011-03-31 14:50:37