问题 问答题

空气的主要成分是氮气和氧气,其中氮气体积约占空气体积的4/5.

(1)请试用这样的推理方法:“如果氧气有颜色,那么空气就会有颜色;而空气是无色的,所以推测氧气是无色的.”结合你的生活经验,对氮气物理性质进行推测,填写下表:

  颜  色  气  味    水  溶  性
  氮  气
(2)实验室可用亚硝酸钠(NaNO2)固体和氯化铵(NH4Cl)溶液混和加热来制取氮气.现提供如下实验装置,则实验室制取氮气应采用的发生装置是______,收集装置是______.(填字母)

(3)工业上常用氮气与氢气在高温、高压及催化剂条件下合成氨气,化学反应方程式为______.

N2+3H2

  催化剂  
.
高温高压
2NH3.现欲制取氨气1.7吨,理论上需要在0℃和标准大气压下的氮气多少升?(已知O℃和标准大气压下氮气的密度为1.25克/升;假设氮气完全转化为氨气)

答案

(1)根据题目信息和生活常识可知,因为空气没有颜色和气味,所以氮气也没有颜色和气味,故答案为:

  颜色 气味 水溶性
 氮气 无色 无味 难溶
(2)实验室可用亚硝酸钠(NaNO2)固体和氯化铵(NH4Cl)溶液混和加热来制取氮气,发生装置是固体和液体加热制取气体;因为氮气不溶水,所以采用排水法收集;故答案为:C  F

(3)设需要N2质量为x

N2+3H2

  催化剂  
.
高温高压
2NH3

28               34

x               1.7吨

28
x
34
1.7t

则:x=1.4吨

则:V=1.4×l06÷1.25═1.12×l06L

答:现欲制取氨气1.7吨,理论上需要在0℃和标准大气压下的氮气1.12×l06L.

多项选择题
问答题

[说明]
假定用一个整型数组表示一个长整数,数组的每个元素存储长整数的一位数字,则实际的长整数m表示为:
m=a[k]×10k-2+a[k-1]×10k-3+…+a[3]×10+a[2]
其中a[1]保存该长整数的位数,a[0]保存该长整数的符号:0表示正数、1表示负数。
运算时先决定符号,再进行绝对值运算。对于绝对值相减情况,总是绝对值较大的减去绝对值较小的,以避免出现不够减情况。注意,不考虑溢出情况,即数组足够大。
[函数]
int cmp(int *LA, int *LB);
/*比较长整数LA与LB的绝对值大小*/
/*若LA绝对值较大返回正值,LA较小返回负值,相等则返回0*/
int ADD (int *LA, int *LB, int *LC)
/*计算长整数LA与LB的和,结果存储于LC中*/
/*注意:正数与负数的和相当于正数与负数绝对值的差*/
/*数据有误返回0,正常返回1*/

if(LA == NULL || LB == NULL || LC == NULL)return 0;
int *pA, *pB, i, N, carry, flag;
flag = LA[0] + LB[0];
switch(flag) /*根据参与运算的两个数的符号进行不同的操作*/
case 0:
case 2:
Lc[0] = LA[0];/*LA与LB同号,结果符号与LA(LB)相同*/
pA = LA;
pB = LB;
(1) ;
break;
case 1: /*LA与LB异号*/
/*比较两者的绝对值大小,结果符号与较大者相同*/
flag = (2) ;
if(flag > 0) /*LA较大*/
LC[0] = LA[0];
pA = LA;
pB = LB;

else if(flag < 0)(/*LB较大*/
LC[0] = LB[0];
pA = LB;
pB = LA;

else/*LA与LB相等*/
LC[0] = 0;
LC[1] = 0;
return 1;

flag = -1;
break;
default:
return 0;
break;
/*switch*/
/*绝对值相加减*/
/*注意对于减法pA指向较大数,pB指向较小数,不可能出现不够减情况*/
(3) ;
N = LA[1] > LB[1] LA[1] : LB[1];
for(i = 0; i < N; i++)
if(i >= pA[1])/*LA计算完毕*/
carry += flag * pB[i+2];

else if(i >= pB[1])/*LB计算完毕*/
carry += pA[i+2];

else
carry += pA[i+2] + flag * pB[i+2];

LC[i+2] = carry % 10;
carry /= 10;
if( (4) )/*需要借位,针对减法*/
LC[i+2] += 10;
carry--;

/*for*/
if( (5) )/*最高进位,针对加法*/
LC[i+2] = carry;
i++;

if(LC[i+1] == 0) i--; /*若最高位为零,针对减法*/
LC[1] = i;
return 1;
;/*ADD*/