以下哪个是面向对象的高级语言( )。
汇编语言
C++
Fortran
Basic
若有如下程序段,其中 s、a、b、c 均已定义为整型变量,且 a、c 均已赋值,c > 0。
s = a;
for (b = 1; b <= c;
b++) s += 1;
则与上述程序段功能等价的赋值语句是( )。
s=a+b
s=a+c
s=s+c
s=b+c
设有 100 个数据元素,采用折半搜索时,最大比较次数为( )。
6
7
8
10
有向图中每个顶点的度等于该顶点的( )。
入度
出度
入度与出度之和
入度与出度之差
一棵具有 5 层的满二叉树中结点数为(. )。
31
32
33
16
有以下程序:
#include <iostream> using namespace std; int main() { int s, a, n; s = 0; a = 1; cin >> n; do { s += 1; a -= 2; } while (a != n); cout << s << endl; return 0; }
若要使程序的输出值为 2,则应该从键盘给 n 输入的值是( )。
-1
-3
-5
0
设变量 x 为 float 型且已赋值,则以下语句中能将 x 中的数值保留到小数点后两位,并 将第三位四舍五入的是( )。
x=(x*100)+0.5/100.0;
x=(x*100+0.5)/100.0;
x=(int)(x*100+0.5)/100.0;
x=(x/100+0.5)*100.0;
要求以下程序的功能是计算:s = 1 + 1/2 + 1/3 + ... + 1/10。
#include <iostream> using namespace std; int main() { int n; float s; s = 1.0; for (n = 10; n > 1; n--) s = s + 1 / n; cout << s << endl; return 0; }
程序运行后输出结果错误,导致错误结果的程序行是( )。
s=1.0;
for(n=10;n>1;n--)
s=s+1/n;
cout<<s<<endl;
下列几个 32 位 IP 地址中,书写错误的是( )。
162.105.117.27
192.168.0.1
256.256.129.1
10.0.0.1
下列各无符号十进制整数中,能用八位二进制表示的数中最大的是( )。
296
133
256
199
链表不具有的特点是( )。
不必事先估计存储空间
可随机访问任一元素
插入删除不需要移动元素
所需空间与线性表长度成正比
下列选项中不属于图像格式的是( )。
JPEG格式
TXT格式
GIF格式
PNG格式
以下哪一种是属于电子邮件收发的协议( )。
SMTP
UDP
P2P
FTP
断电后会丢失数据的存储器是( )。
RAM
ROM
硬盘
光盘
CPU、存储器、I/O 设备是通过( )连接起来的。
接口
总线
控制线
系统文件
下列对操作系统功能的描述最为完整的是( )。
负责外设与主机之间的信息交换
负责诊断机器的故障
控制和管理计算机系统的各种硬件和软件资源的使用
将源程序编译成目标程序
以下哪一种设备属于输出设备( )
扫描仪
键盘
鼠标
打印机
二进制数 00100100 和 00010101 的和是(. )
00101000
001010100
01000101
00111001
1TB 代表的字节数量是( )。
2 的 10 次方
2 的 20 次方
2 的 30 次方
2的40次方
计算机界的最高奖是( )。
菲尔兹奖
诺贝尔奖
图灵奖
普利策奖
#include <iostream> using namespace std; int main() { int a, b, c, d, ans; cin >> a >> b >> c; d = a - b; a = d + c; ans = a * b; cout << "Ans = " << ans << endl; return 0; }
输入:2 3 4
输出:_________
#include <iostream> #include <string> using namespace std; int main() { string st; int i, len; getline(cin, st); len = st.size(); for (i = 0; i < len; i++){ if (st[i] >= 'a' && st[i] <= 'z') st[i] = st[i] - 'a' + 'A'; } cout << st << endl; return 0; }
输入:Hello, my name is Lostmonkey.
输出:_________
#include <iostream> using namespace std; int fun(int n) { if (n == 1) return 1; if (n == 2) return 2; return fun(n - 2) - fun(n - 1); } int main() { int n; cin >> n; cout << fun(n) << endl; return 0; }
输入:7
输出:_________
#include <iostream> using namespace std; const int SIZE = 100; int main() { int p[SIZE]; int n, tot, i, cn; tot = 0; cin >> n; for(i = 1; i <= n; i++) p[i] = 1; for(i = 2; i <= n; i++){ if (p[i] == 1) tot++; cn = i * 2; while (cn <= n) { p[cn] = 0; cn += i; } } cout << tot << endl; return 0; }
输入:30
输出:_________
(数字删除)下面程序的功能是将字符串中的数字字符删除后输出。请填空。
#include <iostream> using namespace std; int delnum(char *s) { int i, j; j = 0; for (i = 0; s[i] != '\0'; i++) if (s[i] < '0' (1) > '9') { s[j] = s[i]; (2) ; } return (3) ; } const int SIZE = 30; int main() { char s[SIZE]; int len, i; cin.getline(s, sizeof(s)); len = delnum(s); for (i = 0; i < len; i++) cout<< (4) ; cout << endl; return 0; }
(最大子矩阵和)给出 m 行 n 列的整数矩阵,求最大的子矩阵和(子矩阵不能为空)。
输入第一行包含两个整数 m 和 n,即矩阵的行数和列数。之后 m 行,每行 n 个整 数,描述整个矩阵。程序最终输出最大的子矩阵和。
#include <iostream> using namespace std; const int SIZE = 100; int matrix[SIZE + 1][SIZE + 1]; int rowsum[SIZE + 1][SIZE + 1]; //rowsum[i][j]记录第 i 行前 j 个数的和 int m, n, i, j, first, last, area, ans; int main() { cin >> m >> n; for (i = 1; i <= m; i++) for (j = 1; j <= n; j++) cin >> matrix[i][j]; ans= matrix (1) ; for (i = 1; i <= m; i++) (2) ; for (i = 1; i <= m; i++) for (j = 1; j <= n; j++) rowsum[i][j] = (3) ; for (first = 1; first <= n; first++) for (last = first; last <= n; last++) { (4) ; for (i = 1; i <= m; i++) { area+= (5) ; if (area > ans) ans = area; if (area < 0) area = 0; } } cout << ans << endl; return 0; }