#include "stdio.h"
#include "stdafx.h"
#include "iostream"
using namespace std;
int main()
{
char c[256], d[256];
int i = 0;
while
((c[i++] = getchar()) != '\n');
c[i] = '\0';
i = 0;
printf("%s", c);
printf("\n");
while (c[i])
{
if ('a' <= c[i] && c[i] <= 'z')
{
c[i] -= 32;
}
else if ('A' <= c[i] && c[i] <= 'Z')
{
c[i] += 32;
}
d[i] = c[i];
i++;
}
printf("%s", d);
printf("\n");
return 0;
}
如图代码所示,每次转化后都会多输出一行乱码,问题已经解决,
我把while(c[i])换成while(i<sizeof(c))就输出正常了,我想知道为什么
while(c[i])有什么错误,多谢大神~!
建议你先初始化数组 c 和 d 的所有元素为零,因为局部变量的初始值是随机的。
假如你只给 c 和 d 的前 100 个元素赋值了,才能后面的 156 个元素的值就是随机数。当你用 c[i] 判断时,因为没有 0 数值的存在,导致越界了。
如果输入的字符串超过了你数组c的大小,就会导致c的结尾字符不是数组的最后一个元素,就会输出后面的内容空间的内容
只是,定义了数组,但未对数组初始化。此时,数组是空的。
sizeof(c[i])返回该元素定义时的字节数,是整型。所以就OK。
如果你用do while循环就没有这个问题了,这样就把\0也拷贝到d中了,不过建议凡是用到结构类变量先进行清0操作
如果你用do while循环就没有这个问题了,这样就把\0也拷贝到d中了,不过建议凡是用到结构类变量先进行清0操作
初始化数组,然后应该就没有这个问题了
初始化数组,然后应该就没有这个问题了
数组大半部分都没有赋值,全都初始化为0了。。。