下列选项中正确的定义语句是A.double,a,b
来源:学生作业帮助网 编辑:作业帮 时间:2024/11/18 12:00:12
c其中==号是判断语句,不是赋值语句
A)inta=b=0;//b未定义B)charA=65+1,b='b';//正确C)floata=1,*b=&a,*c=&b;//*c=&b,应该是*c=bD)doublea=0.0;b=1.1;//
答案是B,DA:等价于a=(b=0),即b=0;a=b.先对b赋0,然后再传给a,但是=右边必须是量,所以不正确.C:C是指向指针的指针,应该为**c=&b再问:答案给的是B,所以我觉得D也是对,所以
答案为C:对于二维数组,在声明时必须指定二维数组第二维的数量,因此,只有C是正确的对于A和D都不能确定二维数组第二维是多少.
选C吧.scanf的第二个参数是一个地址.要么是个指针,如p;要么是取地址符加变量,如&c.
答案是C解决这类题型首先要分清类型.A错,虽然p的类型是(int**),a的类型是(int**),但是数组名代表的地址也不能改变.B错,因为p[0]的类型是(int*),a的类型是(int**).C对
n是整数,p是整数指针,q是双重指针.A:p=1属于将地址1赋给p,非法.B:*q=2这里*q相当于一个整数指针,问题同上,非法.C:q=p相当于把p的地址赋给q,不能说错,但是不同维数的指针互相赋值
0)w=a=bw的类型和ab不同,类型不同占用的存储空间和存放的寄存器也不一样,如果要赋值需重新对类型进行注释:w=(int)a=(int)b0)a=a++=5连环赋值是c和C++特有用法,顺序是从右
Da,b是double类型,如果ab是0.1,就会出现除数是零了,就出错了,D是对的,先判断,后赋值,这样允许的!
选AAa='&'是正确的Ba=’16’因为a是被定义为char,所以必须是字符,而16是字符串,不是字符,所以是错的Ca=”&”;是因为定义chara,不是stringa,字符串是用“”引的,而字符时
选CA中switch(x%2),x为实数,不能求余B中(int)x%2.0,2.0为实数,不能求余D中case0.0:a++;break;case1.0:b++;break;case中不能用实数常量,
是的选c,A)switch(x%2)中的x没有保证是整数而%要求两边都必须是整数B)switch((int)x/2.0中()优先级高于/得到的数并不是整数而是浮点数D)switch((int)(x)%
选B再问:能不能解释一下为什么?再答:其实我看错了应该选C,D的A的a+b是表达式不能作左值B项中(int)a+b是double类型的不能作%的除数CD是对的弱类型的变量可以赋给强类型的变量但是不能反
A.数据类型不可以是double没这规定!B.数组名可以选C的保留字C的保留字不允许做变量名、函数名!C.长度是一个任意的整型表达式长度需要大于0D.一个数据定义语句中不可以定义数据类型不同的多个数组
选C在同一行连续定义相同类型的变量,变量之间要用逗号分开,变量和类型之间不能有逗号.
D,A我用visualc++试过,说左操作必须为左值,就是说只能a=a+b,或a=b++;B显然被除数必须为整数.C除数和被除数不是同一类型.
这道题你可以带入数字去验证:设a=1,b=2.A选项:a=a+b=1+2=3,此时a=3(a得到新值),b=a-b=3-2=1此时b=1,a=3-1=2此时a=2,很明显A成立B选项:t=a就是t得到
第四个是正确的,二维数组在定义时,必须指定列数
C中N是变量,D中N是常量!再问:但是C中N也是2008啊。是不是定义的时候一定要常量的?再答:静态数组的长度一定是常量!因为在你定义一个数组时电脑就要在内存中为该数组分配你所需要长度的空间了,但如果
D.意思是,下面能正确定义数组的是就是D啊#defineN2008其中的N是可以定义数组的,intnum[N],这里N是常量A选项中不能那样定义,可以这样intnum[2008],B选项中intnum