扩展资料:
C语言是一门通用计算机编程语言,广泛应用于底层开发。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。
二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。[1] 目前2011年12月8日,国际标准化组织(ISO)和国际电工委员会(IEC)发布的C11标准是C语言的第三个官方标准,也是C语言的最新标准,该标准更好的支持了汉字函数名和汉字标识符,一定程度上实现了汉字编程。
C语言是一门面向过程的计算机编程语言,与C++,Java等面向对象的编程语言有所不同。
其编译器主要有Clang、GCC、WIN-TC、SUBLIME、MSVC、Turbo C等。
本回答被网友采纳执行scanf的代码:
#include<stdio.h>
int main()
{
int n;
int t=0;
scanf("%d",&n);
char arr[n];
int i;
for(i=0;i<n;i++)
{
scanf("%c",&arr[i]);
}
printf("%c\n",arr[0]);
for(i=0;i<n;i++)
{
if(arr[i]=='L')
{
t=t+1;
}
else if(arr[i]=='R')
{
t=t-1;
}
}
printf("%d\n",t);
}
可以观察到,arr[0]并未存入字符,t的数值比预期少1
原因:这种情况通常发生在前面已经有了输入语句,而当前的scanf是在接收字符(即用%c控制输入)时。由于前面的输入语句(不一定是scanf)把最后输入的'\n'遗留在了输入缓冲区,而当前的scanf("%c",...);又会把'\n'当一个字符接收,又由于scanf在%c控制下只接收一个字符,所以就不能接收正式输入的字符了。解决这一问题的最简单办法是在接收字符的scanf的控制符"%c"中的%前加一个空格写成" %c",把前一次输入遗留在输入缓冲区里的所有广义空格(' '、'\t'、'\n'等)都吸收掉。在接收字符的scanf前加getchar()等的办法其实是有漏洞的——当缓冲区里只遗留了一个广义字符时可正常工作,若多于一个则同样出错。
改正错误之后的代码:
#include<stdio.h>
int main()
{
int n;
int t=0;
scanf("%d",&n);
char arr[n];
int i;
for(i=0;i<n;i++)
{
scanf(" %c",&arr[i]);
}
printf("%c\n",arr[0]);
for(i=0;i<n;i++)
{
if(arr[i]=='L')
{
t=t+1;
}
else if(arr[i]=='R')
{
t=t-1;
}
}
printf("%d\n",t);
}
将scanf中的%c变为 %c,得到预期结果。
本回答被网友采纳char 类型数组,可以用字符串操作输入一连串的字符。char str[100] ; scanf("%s", str );