作业2.2

一.选择题

1、编写C++程序一般需经过的几个步骤依次是( B )

A. 编辑、调试、编译、连接

B. 编辑、编译、连接、运行

C. 编译、调试、编辑、连接

D. 编译、编辑、连接、运行

2、所谓数据封装就是将一组数据和与这组数据有关操作组装在一起,形成一个实体,这实体也就是( A )

A.

B. 对象

C. 函数体

D. 数据块

3、在C++中,使用流进行输入输出,其中用于屏幕输入( A )

A. cin

B. cerr

C. cout

D. clog

4、关于对象概念的描述中,说法错误的是(A)

A. 对象就是C语言中的结构变量

B. 对象代表着正在创建的系统中的一个实体

C. 对象是类的一个变量

D. 对象之间的信息传递是通过消息进行的

5、在C++语言中,数据封装要解决的问题是(D)

A. 数据的规范化

B. 便于数据转换

C. 避免数据丢失

D. 防止不同模块之间数据的非法访问

6、在面向对象的程序设计中,首先在问题域中识别出若干个 (B)

A. 函数 B.C. 文件 *D.*过程

7、在下列成对的表达式中,运算结果类型相同的一对是(D)

A. 7.0/2.0和7.0/2

B. 5/2.0和5/2

C. 7.0/2和7/2

D. 8/2和6.0/2.0

8、函数调用func((exp1,exp2),(exp3,exp4,exp5))中所含实参的个数为(C)

A. 5 B. 4 C. 2 D. 1

9、执行语句

char ch[] = "Hello";

char * p = &ch[0];

cout << p;

结果是输出 ______________。

A. 一个地址 B. H C. Hello D. 乱码

10、下列程序的输出结果是(A)

#include <iostream.h>

void main()

{ int n[][3]={10,20,30,40,50,60 };

int (*p)[3];

p=n;

cout<<p[0][0]<<","<<*(p[0]+1)<<","<<(*p)[2]<<endl; }

A. 10,30,50

B. 10,20,30

C. 20,40,60

D. 10,30,60

二.填空题1、执行下列代码

cout<<"oct:"<<oct<<34;

程序的输出结果是++oct:34++。

2、C++的流库预定义了4个流,它们是cin、cout、clog和_cerr_。

3、表达式cout<<end1 还可表示为++cout << '\n'++。

4、下面程序的输出结果为_5__。

#include <iostream.h>

void main()

{ int num=2,i=6;

do

{i--;

num++;

}while(--i);

cout<<num<<endl;

}

5、int n=0;

while(n=1)n++;

while循环执行次数是__无数次_。

6、给出下面程序输出结果。结果为28

#include <iostream.h>

int a[8]={1,2,3,4,5,6,7};

void fun(int *pa,int n);

void main()

{int m=8;

fun(a,m);

cout<<a[7]<<endl;

}

void fun(int *pa,int n)

{for (int i=0;i<n-1;i++)

*(pa+7)+=*(pa+i);

}

运行程序,写出程序执行的结果。

7、给出下面程序输出结果。结果为20

#include <iostream.h>

void main()

{ int *p1;

int **p2=&p1;

int b=20;

p1=&b;

cout<<**p2<<endl;

}

8、 #include <iostream.h>

void main()

{ int a,b,c;

char ch;

cin>>a>>ch>>b>>c;//从键盘上输入1.5×c×10×20,×表示一个空格

cout<<a<<endl<<ch<<endl<<b<<endl<<c<<endl;

}

结果为:

1

c

10

20

9、在下面程序横线处填上适当内容,使程序执行结果为:

S=2

S=5

S=9

#include <iostream.h>

void sum(int i)

{ static int s;

s=s+i+2_;

cout<<"s="<<s<<endl;

}

void main (void)

{ int i;

for (i=0;_ i<3__;i++)

sum(i);

}

10、下面是一个三角形三边,输出其面积C++程序,在下划线处填上正确的语句。

#include <iostream.h>

#include <math.h>

void area()

{double a,b,c;

cout<<"Input a b c:";

cin>>a>>b>>c;_

if(a+b>c&&a+c>b&&c+b>a) // 三角形 任意2边大于第三边

{ double l=(a+b+c)/2; // 半周长

double s=sqrt(l*(l-a)*(l-b)*(l-c)) // 海伦公式

cout<<"The area is:"<<s<<endl;

}

else

cout<<"Error"<<endl;

}

void main()

{ area(); }

三、编程题

3.1 、创建一个程序,输出8个随机大小写字母或数字组成的密码,允许输入重复的字符

cpp 复制代码
#include <iostream>

#include <string>

using namespace std;

int my_Random(int seed)

{

    int a = 11451;

    int c = 12345;

    seed = (a * seed + c) % 1024;

    return seed;

}

int main()

{

    int seed = 123;

    string buffer = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

    string password;

    for (int i = 0; i < 8; i++)

    {

        seed = myRandom(seed);

        int index = seed % buffer.length();

        password += buffer[index];

}

    cout << "生成的密码为:" << password << endl;

    return 0;

}
相关推荐
We་ct8 分钟前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
JAVA面经实录9173 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程4 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
周杰伦fans4 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
叼烟扛炮5 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说5 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove6 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung6 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了6 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL6 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化