大家好,这里是国中之林!
❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看←
问题:
解答:
#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也一样可以哦.