为什么要多加这一步
为什么要多加这个while,我这样直接不可以么 你输入一行英文句子:假如你输入: ilove fishc.com 那么它的原型是 ilove fishc.com\n
也就是说 不管你输什么,后面有个\n是没有显示出来的
ba21 发表于 2018-10-11 10:47
你输入一行英文句子:
假如你输入: ilove fishc.com 那么它的原型是 ilove fishc.com\n
但是我不要计算那个\n啊我只要计算大写字符就好了,但是为什么我这样他就算不到了呢 本帖最后由 calton007 于 2018-10-11 11:39 编辑
getchar()>='A' && getchar()<='Z'
getchar()函数调用了两次,从缓冲区获取两个字符,并不是同一个字符
如果这样写循环条件变成了,读取两个字符,第一个字符的ASCII比'A'大,第二个字符的ASCII比'Z'小,这两个条件同时满足,count+1
举个例子,假设输入"a a a "(小写字母a和空格),这个字符串是满足循环条件的,count结果为3,显然不符合统计大写字母的要求
while((c = getchar()) != '\n')
定义了一个char变量c存读取的字符,执行getchar()读取字符并给c赋值,然后判断读取的字符是否是'\n',保证判断的是同一个字符
循环大多数情况下都是要有结束的,这里定义为读取到'\n'字符的时候结束循环,因此如果输入为'\n',循环条件不满足,循环就结束了,'\n'字符是不会统计的
calton007 发表于 2018-10-11 11:36
getchar()函数调用了两次,从缓冲区获取两个字符,并不是同一个字符
如果这样写循环条件变成了,读取两 ...
我懂了,谢谢 回车会被getchar()捕获 我也懂了,我只是路过而已
页:
[1]