问题描述
- C语言数组大小写转化后多输出一行乱码
-
#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] = ''; 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循环就没有这个问题了,这样就把也拷贝到d中了,不过建议凡是用到结构类变量先进行清0操作
解决方案五:
如果你用do while循环就没有这个问题了,这样就把也拷贝到d中了,不过建议凡是用到结构类变量先进行清0操作
解决方案六:
初始化数组,然后应该就没有这个问题了
解决方案七:
初始化数组,然后应该就没有这个问题了
解决方案八:
数组大半部分都没有赋值,全都初始化为0了。。。
时间: 2024-09-11 18:16:21