2020.2.26
今天写了一道很简单的题,用递归解,但是处理输入格式就花了很多时间,在答案区找了很久,发现大家写的都很复杂,既然输入函数是必须使用的,那么为什么不好好研究一下呢?
第一种:
[123,2,3,4,5]
这种输入的处理办法
char c;
int a[10000];
while ((c = getchar()) != ']')
{
scanf("%d", &a[i]);
i++;
}
乍一看感觉很奇怪,但是却运行正确,这段代码每次getchar会从缓冲区拿掉一个字符,于是在scanf的时候缓冲区就变成了123,2,3,4,5],而当%d遇到数字时会将数字拿走,没有遇到数字时,会被getchar拿走,直到遇到’]’
其他的以后再补充
2020.3.10
当我们想模拟用字符串作为输入时,可以用sscanf,stringstream,分别替代c/c++;