欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    江苏省计算机二级c++考试试题集.docx

    • 资源ID:17528707       资源大小:836.14KB        全文页数:70页
    • 资源格式: DOCX        下载积分:6金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要6金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    江苏省计算机二级c++考试试题集.docx

    1、江苏省计算机二级c+考试试题集2006年(秋)笔试试卷第二部分 Visual C+程序设计一、选择题(用答题卡答题,答案依次填在(21)(30)答题号内)21.下列叙述中,不正确的是 (21) 。A一个函数中可以有多个return语句 B函数可通过return语句返回数据C必须用一个独立的语句来调用函数 D函数main也可以带有参数(22) 。Afloat i, j, int k; Bconst int i; (23) 。 A构造函数可以重载,析构函数不能重载 B构造函数不能重载,析构函数可以重载 C构造函数可以重载,析构函数也可以重载 D构造函数不能重载,析构函数也不能重载24. 执行以下程

    2、序时,循环的次数是 (24) 。 for ( int x = 0, y = 0; !x& yp; Bcoutq; Dcoutq;28. 下列关于赋值兼容规则的描述中不正确的是(28) 。A派生类的对象可以赋值给基类的对象B基类的对象可以赋值给派生类的对象C派生类的对象可以初始化其基类的引用D可以将派生类对象的地址赋值给其基类的指针变量29. 下列关于变量的叙述中不正确的是(29) 。AC+语言中将变量分为auto、static、extern和register四种存储类型B自动变量和外部变量的作用域为整个程序文件 C函数内定义的静态变量的作用域为定义它的函数体 D外部静态变量的作用域为定义它的文

    3、件内30. 设有说明语句:char a =”string!”, *p = a;以下选项中正确的是(30) 。Asizeof (a)的值与strlen (a)的值相等 Bstrlen (a)的值与strlen (p)的值相等Csizeof (a)的值与sizeof (p)的值相等 Dsizeof (a)的值与sizeof (*p)的值相等 二、填空题(请将答案填写在答题纸的相应答题号内)基本概念题(共5分)1.当一个类的非静态成员函数被调用时,该成员函数的 (1) 指向调用它的对象。2.C+语言中的友元函数提供了在类外访问类中私有成员和保护成员的功能,但破坏了类的 (2) 。3.使用成员函数对双

    4、目运算符进行重载时,其左操作数是 (3) 。4.设有宏定义和变量说明:#define T(x,y) x+yint a= T( 3, 4 )*T( 3, 5 )则变量a的初值为 (4) 。5.设有说明语句:int a 4=1,2, 2,3,4,5, *p=(int *)a;则*( p+5 )的值为 (5) 。阅读程序题(共13分)6. 【程序】(3分)#include #include int isvowel(char c) return (c=a| c=e| c=i| c=o| c=u); void pluralize(char* s) int len=strlen(s); char *p =

    5、 s+len-1; char *q = s+len-2; if ( *p=h &(*q =c|*q =s) strcat ( p, “es” ); else if ( *p =s ) strcat( p, “es” ); else if ( *p=y ) if ( isvowel (*q ) ) strcat ( p, “s” ); else strcpy ( p, “ies” ); else if ( *p =z ) if ( isvowel (*q ) ) strcat( p, “zes” ); else strcat ( p, “es” ); else strcat ( p, “s” )

    6、;void main(void) char word620=“wish”, “bus”, “toy”, “navy” ,“quiz”, “computer” ; for( int i=0; i6; i+) pluralize( word i ); coutword i t; if( ( i+1 )%2 = 0) cout n; 程序输出的第一行是 (6) ,第二行是 (7) ,第三行是 (8) 。7. 【程序】(3分)#include void f ( int j ) if ( !j ) coutj; return ; if ( j%2 ) f ( j/10 ); cout j%10; els

    7、e cout j%10; f ( j/10 ); void main(void) f ( 0 ); coutn; f ( 1357 ); coutn; f ( 2468 ); coutn;程序输出的第一行是 (9) ,第二行是 (10) ,第三行是 (11) 。8. 【程序】(3分)#include int x =2, y = x+30;class A int y; static int x; public: operator int ( ) return x+y; A operator + ( int ) return A ( x+, y+ ); A ( int x =2, int y =3

    8、 ) A:x =:x + x; A:y =:y + y; void print( ) cout ”x=” x ”,t” ”y=” y endl; ;int A:x =23;void main(void) A a (54, 3 ), b ( 65 ), c;a.print( );int i =a+b; cout ”i = ” i endl; c + + ; c.print ( );程序输出的第一行是 (12) ,第二行是 (13) ,第三行是 (14) 。9. 【程序】(2分)#include char* f( char* s, char ch ) char* p = s, *q = s; wh

    9、ile (*q =*p+ ) if ( *q!= ch ) q+; return s;void main(void) char s1 =”Hello How are you”, s2 =”1100101 11”; coutf ( s1,e ) n; cout f ( s2, 0 ) n;程序输出的第一行是 (15) ,第二行是 (16) 。10. 【程序】(2分)#include class A int x, y; public: A( int i , int j ) x = i; y = j; operator + ( int ) cout + x + y ”重载1” n; friend A

    10、 opertor + (A);A opertor + (A op ) cout + op.x + op.y ”重载2” n; void main(void ) A a ( 1, 2 ); +a; a+; 程序输出的第一行是 (17) ,第二行是 (18) 。完善程序题(共12分)11. 下面程序的功能是:先输入一行字符串,并从输入的字符串中找到最小的字符(其ASCII值最小),用min保存该字符。然后将该字符前的所有字符顺序往后移动一个字符位置。最后,将保存的字符放在该字符串的第0个位置上。例如,设输入的字符串为“bcdfae”,其中字母a为最小字符,经移动处理后,输出的字符串为“abcdfe

    11、”。【程序】(4分)#include void fun( char* str ) char min , *q , *p ; (19) ; min = *p+ ; while ( *p !=0 ) if ( (20) ) min =*p; q = p ; p+; p = q; while( (21) ) *p = *( p-1 ); (22) ; *p = min;void main(void) char str 80 ; cin.getline( str , 80 ); fun ( str ); cout str n;12. 用程序模拟两个大整数(为简化程序,设整数为正数)的加法运算。假定一个

    12、整数最多N位,用一个一维数组存放其各位数字。在数组下标为0的元素中存放该整数的个位数字,在下标为1的元素中存放该整数的十位数字,依此类推。例如,大整数a的值为88099005798957,大整数b的值为776988213577,则两个整数相加的结果为88875994012534。以下是程序输出的结果:Integer a: 88099005798957Integer b: 776988213577 Sum: 88875994012534【程序】(4分)#include #define N 20 /整数的位数void add( int sum , int a , int b ); /sum = a

    13、 + bvoid wrt ( (23) );void main(void) int a N = 7,5,9,8,9,7,5,0,0,9,9,0,8,8; int b N = 7,7,5,3,1,2,8,8,9,6,7,7; int sum N ; add (sum , a , b); wrt (“Intrger a:”, a); wrt( “Intrger b:”, b); wrt (“ Sum:”, sum);void add ( int sum , int a , int b ) int carry = 0, i; /carry表示进位 for ( i = 0; iN; + i ) sum

    14、 i = (24) ; if ( sum i 10 ) carry = 0 ; else carry = sum i /10; sum i = (25) ; void wrt ( const char* s, int a ) int i; cout 0 &a i =0 ; -i ) /输出前导空格 cout=0 ; -i ) cout a i ; cout n ;13. 下面程序先建立一条单向链表,其中每个结点包含产品名称和产品类别。然后对链表中的结点按产品类别进行分类,将同类别产品的结点放在一起。具体实现过程为:依次从已建立的链表上取下一个结点,根据该结点的产品类别值插入到新的链表中。插入过

    15、程为:若新链表上已有该产品类别的结点,则将结点插入到同类别结点的最后一个结点的后面;否则,将该结点插入到新链表的最后一个结点的后面。最后,输出分类后链表上各个结点的信息。【程序】(4分)#include #include struct node char product20; /产品名称 char category10; /产品类别 node * next;node * create( void ) /创建链表 node temp, *p2=&temp; char product20, category10; while( 1 ) coutproductcategory; if( strcmp

    16、(product, “end” ) =0 ) break ; p2-next = new node; p2=p2-next; strcpy( p2-product, product ); strcpy( p2-category, category ); (27) ; return temp. next;void print( node* h ) /输出链表h while(h) coutproduct t category next; coutnext; delete p; node* insertascategory( node * h , node * p ) /按类别插入结点 node *

    17、 p2 =0 , *p1 = h; if ( h=0 ) p-next = 0; return p; while ( p1&strcmp( p1-category, p-category ) ) p2 = p1; p1 =p1-next; /找同类结点 while ( p1&strcmp( p1-category, p-category ) =0 ) p2 = p1; p1 =p1-next; /定位在同类结点后 p-next = p1; (29) ; /插入在p1、p2结点之间 return h;node* classify( node* h ) /按类别分类 node* h2 = 0, *

    18、p; while( h ) p=h; (30) ; h2= insertascategory( h2, p ); return h2;void main(void) node* h; h= create( ); print( h ); h= classify( h ); print( h ); deletechain ( h );2007年(春)笔试试卷第二部分 Visual C+程序设计一、选择题(用答题卡答题,答案依次填在(21)(30)答题号内)21.设有变量说明:“short int a=0,b=0;”,则表达式sizeof(a+b)的值为 (21) 。A1 B2 C4 D8while

    19、循环语句的叙述中正确的是(22) 。Adowhile的循环体至少执行一次Bwhile的循环体至少执行一次Cdowhile的循环体不能是复合语句Ddowhile允许从循环体外跳转到循环体内23. 设有函数原型说明: void test(int a, int b=7, char * c=”# ” ); 下面的函数调用中存在语法错误的是 (23) 。 Atest ( 3 ) Btest( 3, 8.2) Ctest(6, ”*” ) Dtest(0, 0, ”*”)24. 执行以下程序时,输入一行字符串为Thank you very much!程序的输出结果为 (24) 。 #include voi

    20、d main(void) char line100; cinline; coutlinen; AT BThankCThank you very much! DThank you25. 下列关于运算符重载的叙述中正确的是(25) 。A运算符重载可以改变操作数的个数B运算符重载可以改变运算符的优先级C运算符重载可以改变运算符的结合性D运算符重载不能改变操作数的个数,也不能改变运算符的优先级和结合性26. 定义以下的类:class X int a; public: X( int x=0) a=x; ;class Y: public X int b; public: Y(int x=0,int y=0

    21、): X(y) b=x; ; 在以下选项的说明语句中,存在语法错误的是(26) 。 AX * pa= new Y(1,2); BX a1=Y(1,3); CX b2(2,3); Y & a2=b2; DY b3(10); X a3(b3);27. 设有以下语句:int a=5; int arra; /第1行const int b=5; int xb; /第2行int c=5; int * p=new intc; /第3行const int d=5; int * p1=new intd; /第4行其中存在语法错误的是(27) 。A第1行 B第2行 C第3行 D第4行28. 设有说明语句:floa

    22、t a33=1,2,3,4,5, *b3=0, (*c)3=a, *d=0;以下选项中语法正确的语句是(28) 。 Aa0=b0; Bb0=c0; Cc0=d0; Dd0=a00;29. 下列关于虚函数的描述中正确的是(29) 。A虚函数可以是一个static类型的成员函数B虚函数可以是一个非成员函数C虚函数可以实现静态多态性D基类中采用virtual说明一个虚函数后,派生类中定义相同原型的虚函数时,可不必加virtual说明30. 设变量a、b是整型变量,下列switch语句中语法正确的是(30) 。Aswitch(a) Bswitch(a+b)case a: a+; break; case

    23、 1: b=a+; break;case b: b+; break; case 1: a=+b; Cswitch(a*a) Dswitch(a/10+b) case 10,12:+a; case 3: b=a/10;break; case 14,16:+b; default: a+=b; 二、填空题基本概念题(共5分)6.对于switch( e ),表达式e只能是整型、 (1) 或枚举型表达式。7.面向对象程序设计的三大特性是封装性、继承性和 (2) 。8.执行以下语句后,a的值为 (3) 。 int a=0,m=3,n=10; a=(m+,m+n);9.在C+中,标识符是以字母或 (4) 开

    24、头的,由字母、数字和 (4) 组成的字符序列。10.在C+中,类的每一个非静态成员函数都有一个 (5) 指针,该指针指向正在调用成员函数的对象。阅读程序题(共13分)6. 【程序】(2分)#include int fun(int x, int y) x=x+y; y=x+y; cout”x=”x”,y=”yendl; return x+y;void main(void) int x=5, y=8, z=fun(x,y); cout” x=”x”,y=”yendl; cout”z=”zendl;程序输出的第二行是 (6) ,第三行是 (7) 。7. 【程序】(3分)#include int f(

    25、int m,int &n) static int a=1; int c=2; m+=+a; n+=+c; return m+n;void main(void) int a=1, b=2; coutf(a,b)n; coutatbn; coutf(f(a,b),b)n;程序输出的第一行是 (8) ,第二行是 (9) ,第三行是 (10) 。8. 【程序】(2分)#include void findmax(int* a, int n, int i, int * pk) if(ia*pk ) *pk=i; findmax ( a,n,i+1,pk); void main(void) int a10=34,32,23,12,67,54,44,60,33,24, index=0; findmax( a,10,0,&index); coutaindexn; cout”Its index is:”indexn;程序输出的第一行是 (11) ,第二行是 (12) 。9. 【程序】(3分)#include int a=100;int fun( int* a, int& b,int c) static int e; *a+=e+; b+; c+=:a+; e=*a+b+c; return e;


    注意事项

    本文(江苏省计算机二级c++考试试题集.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开