大家好,这里是国中之林!
❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看←
问题:
解答:
#include <iostream>
using namespace std;
void UpperCase(char *str)
{
for (size_t i = 0; i < sizeof(str) / sizeof(str[0]); ++i)
{
if ('a' <= str[i] && str[i] <= 'z')
{
str[i] -= ('a' - 'A');
}
}
}
int main()
{
char str[] = "aBcDe";
cout << "The length of str is " << sizeof(str) / sizeof(str[0]) << endl;
UpperCase(str);
cout << str << endl;
return 0;
}
运行结果:
注意:
- 看似正确,其实错了两个地方,一是长度为5,
sizeof
计算多了一个字符串结束符. - 结果好像都转成了我们想要的,但是如果我换成32位的执行.
运行结果就出问题了.
这是因为sizeof()计算的时候,将将传入的数组当成指针了.
所以我们用strlen()
来替换.
运行结果:
x86也一样可以哦.