1.  以下哪个是面向对象的高级语言( )。
2.  1TB代表的字节数是( )。
3.  二进制数00100100和00010101的和是( )。
4.  以下哪一种设备属于输出设备( )。
5.  下列对操作系统功能的描述最为完整的是( )。
6.  CPU、存储器、I/O设备是通过( )连接起来的。
7.  断电后会丢失数据的存储器是( )。
8.  以下哪一种是属于电子邮件收发的协议( )。
9.  下列选项中不属于图像格式的是( )。
10.  链表不具有的特点是( )。
11.  下列各无符号十进制整数中,能用八位二进制表示的数中最大的是( )。
12.  下列几个32位IP地址中,书写错误的是( )。
13.  要求以下程序的功能是计算: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;   
} 
  									
程序运行后输出结果错误,导致错误结果的程序行是( )。
14.  设变量x为float型且已赋值,则以下语句中能将x中的数值保留到小数点后两位, 并将第三位四舍五入的是( )。
15.  有以下程序
#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输入的值是( )。
16.  一棵具有5层的满二叉树中结点数为( )。
17.  有向图中每个顶点的度等于该顶点的( )。
18.  设有100个数据元素,采用折半搜索时,最大比较次数为( )。
19.  若有如下程序段,其中s、a、b、c均已定义为整型变量,且a、c均已赋值,c>0。
s = a; for(b = 1; b <= c; b++) s += 1;
则与上述程序段功能等价的赋值语句是( )。
20.  计算机界的最高奖是( )。
1.  把M个同样的球放到N个同样的袋子里,允许有的袋子空着不放,问共有多少种不同的放置方法?(用K表示)。
例如,M=7,N=3时,K=8;在这里认为和是同一种放置方法。
问:M=8,N=5时,K=
2.  如图所示,图中每条边上的数字表示该边的长度,则从A到E的最短距离是
1. 
#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
输出:Ans=
2. 
#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
输出:
3. 
#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.
输出:
4. 
#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
输出:
1.  (数字删除)下面程序的功能是将字符串中的数字字符删除后输出。请填空。
   
#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's[i] > '9'){  
   		    s[j] = s[i];          
 		    ;         
        }     
    return ;    
}   

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 <<  ;      
    cout << endl;      
    return 0;   
} 
								
2.  (最大子矩阵和) 给出m行n列的整数矩阵,求最大的子矩阵和(子矩阵不能为空)。
输入第一行包含两个整数m和n,即矩阵的行数和列数。 之后m行,每行n个整数,描述整个矩阵。 程序最终输出最大的子矩阵和。
比如在如下这个矩阵中:
4 4
0 -2 -7 0
9 2 -6 2
-4 1 -4 1
-1 8 0 -2
拥有最大和的子矩阵为:
9 2
-4 1
-1 8
其和为15
3 3
-2 10 20
-1 100 -2
0 -2 -3
最大子矩阵和为128
4 4
0 -2 -9 -9
-9 11 5 7
-4 -3 -7 -6
-1 7 7 5
最大子矩阵和为26
   
#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;  
    for(i = 1; i <= m; i ++)        
        ;
    for(i = 1; i <= m; i++)        
        for(j = 1; j <= n; j++)  
       		 rowsum[i][j] =  ;     
    for(first = 1; first <= n; first++)        
        for(last = first; last <= n; last++){  
            ;  
            for(i = 1; i <= m; i++){  
                area += ;               
                if(area > ans)                
                    ans = area;               
                if(area < 0)                
                    area = 0;             
            }        
        }  
    cout << ans << endl;      
    return 0;  
}