|
谋学网: www.mouxue.com 主要提供奥鹏辅导资料,奥鹏在线作业辅导资料,奥鹏离线作业辅导资料和奥鹏毕业论文以及其他各远程教育作业代写服务,致力打造中国最专业远程教育辅导社区。
, F, o( f4 {9 u* j+ v. o+ V! P2 E9 w
4 a$ W! j: H1 c2 `
一、单选题(共 35 道试题,共 70 分。)V 1. 下列关于赋值运算符重载的说法中正确的是()。
& K$ j3 Q3 f0 X! S+ _. T& a2 aA. 返回值一般是以引用方式返回的对象,而函数体中总是用语句“return *this;”返回this指针所指向的对象
5 W2 T9 m3 m. P/ o( RB. 赋值运算符只能以非成员函数的方式重载; i; \0 ~( Z/ S. T
C. 赋值运算符既可以以成员函数的方式重载,又可以以非成员函数的方式重载
- X7 C9 n8 V& y4 C( PD. 以上均不正确
. H* w: q9 \: ~: o, [1 h& M 满分:2 分
- z+ g. s4 z7 x2. 下列关于成员函数特征的描述中,错误的是()。
5 B7 c" D: V7 v; j& u$ C {A. 成员函数可以重载 k* q/ H: X& C) v+ W
B. 成员函数一定是内联函数
0 x/ h" {! Z! D, ?C. 成员函数可以设置参数的默认值, i9 d% k8 [4 t
D. 成员函数可以是静态的
3 X0 p3 Y* m3 t& ^ 满分:2 分
( V) m7 i/ ]3 I, v# v3. 派生类中的成员不能访问基类中的()。
9 c' z }0 S7 N. {2 UA. 私有成员
6 [1 F# _) n6 }6 iB. 公有成员
+ Q- m# Q, ~( B7 k/ \: ~( yC. 保护成员
1 T5 ^0 ^4 C: x$ `: pD. 以上都可以4 q9 j# S; d/ M, a" p2 ^* W8 ~+ s
满分:2 分
: A% |9 b* H8 g& r& w% r: b4. 关于纯虚函数和抽象类的描述中,错误的是()。. _1 U. u0 Y) ?+ u+ L6 q
A. 纯虚函数是一种特殊的虚函数,它没有具体的实现。/ N z+ Q8 E J* M* P0 o8 Q0 }
B. 抽象类是指具有纯虚函数的类。. N. ^' j; X5 S1 P4 O A8 a
C. 一个基类中有纯虚函数,该类的派生类一定不再是抽象类。* A# r) D; w1 I: X3 {
D. 抽象类作为基类来使用,其纯虚函数的实现由派生类给出。- N |$ N$ s7 w7 R
满分:2 分
$ z7 ?3 B. t7 \' V5. 下列关于虚函数的说明中,正确的是()。
& [, |1 z5 F, N' V7 c' pA. 从虚基类继承的函数都是虚函数* K5 q' t" n* F# O
B. 虚函数不得是静态成员函数
. U; k5 V& W- b' gC. 只能通过指针或引用调用虚函数
* R& I; i1 l8 l) ~3 b5 T6 e& T3 OD. 抽象类中的成员函数都是虚函数: u9 X7 V E3 i5 k+ @' [
满分:2 分* X1 c9 b" G7 ^1 }9 V' A
6. 假设堆内存分配均成功,则下面程序段完全正确的是()。
7 J1 D- A$ ~. m2 e+ A' O0 } LA. int *p=new int(3);cout<<*p;delete p;& W* h3 E: x. W! l0 I
B. int *p=new int[5]={1,2,3,4,5};for(int i=0;i<5;i++)cout<<p;delete []p;, e6 L8 Y4 Y% D7 r
C. int *p=new int[5];for(int i=0;i<5;i++,p++) {*p=i; cout<<*p;}delete []p;/ V/ X0 @6 U2 B1 I
D. 以上程序段均正确: p' d) O; J0 ?
满分:2 分
5 q" U, d3 |- x9 F7. 运算符重载的目的是()。) s" }; d. H0 N7 \+ r; x5 D& x1 K
A. 提高程序的效率! E: |& H4 T% n7 R& @
B. 提高代码复用能力
2 s; N$ s2 @& D# F+ v4 _. uC. 简化程序,减少目标代码1 V3 ?! T6 E; ~- n
D. 使程序代码直观易读2 F, F4 L3 N1 O& m
满分:2 分
* C" S" d! T* ?( Q7 k) l, K% G8. 在一个string类对象表示的字符串中查找子串,应该使用string类的()函数。! C* n- Z: e% R6 ?* |
A. assign
6 R- q. l1 b( Z0 O4 K: @B. insert
4 m8 e* i% y M/ C- Q& X2 uC. swap
" J+ d) L( x. Z) o/ e5 TD. find6 u) P" k) p. s$ f1 e$ e/ t
满分:2 分
" e- c. B" _; Z) z/ h% {9. 在一个类中,可以对一个操作符进行()重载。
' K0 `. G; O7 |* S& l2 p% tA. 1种3 X, l2 o7 w; m; O) C+ \+ F
B. 2种' ~7 j% v& E9 F7 G" W1 k. Z3 h
C. 3种
5 R3 I/ S9 ~; k9 OD. 多种
. Y% q& E% {" A; f 满分:2 分1 E* D* }7 f8 N$ }+ t$ \) |
10. 对A、B两个类进行多重继承得到派生类C,则创建派生类C的对象时,从基类B中继承过来的成员变量由()类的构造函数进行初始化。
+ Y `' s+ ?+ U3 i6 r" IA. A1 U% n, E i) b c" x6 G7 M
B. B* g2 Q9 w6 T {8 Y- c
C. C% w/ \ T: f7 [: Q6 f: s4 }
D. 都可以( B; n6 l9 Y! b
满分:2 分 \" f& i& a, r9 P. R
11. 已知“int a=10,*p;int *&r=p; r=&a;*p=20;cout<<a;”,则输出为()。
# a3 [4 M* H& A: q# c$ q J9 JA. 10$ u- ^2 i4 u7 |- j) C' P9 t
B. 20
8 {6 j4 A7 i4 Q ^1 r. J' k. V. jC. 不确定值
8 U( d- {6 c! R" h* Q7 J- FD. 程序有错误4 h" _6 a- w$ [1 [* q
满分:2 分5 n2 U8 ~2 n- b0 X M& N# Y: R
12. 变量的引用,其含义是指该变量的()。" S" _+ r6 D5 ]: j
A. 值
8 k4 ^- D( _' n( y2 U u* R9 iB. 类型& U5 K5 c1 R9 G$ _: q7 f0 b
C. 别名) J- k% c# a/ D1 ~
D. 地址
; S; _3 y5 T8 Q6 N" L' v 满分:2 分
5 i5 ?5 P* _* s' g13. 已知“int a=10,b=8;int &r=a; r=b;cout<<a<<","<<b<<","<<r;”,则输出为()。
! ]) A8 V1 j2 t( g% C; tA. 10,8,10# ~) T$ D* o" f6 r6 B5 t/ _
B. 10,8,81 |2 V j3 B. d& |8 j
C. 8,8,10
3 i5 R( u2 i jD. 8,8,8
1 h0 U# \+ J+ r+ V2 V. ?' v, q# N% @ 满分:2 分
2 J2 t3 d9 `; ]) ^2 y14. 下列关于运算符重载的描述中,正确的是()。
/ r6 ? T4 w: l. u& w6 Y1 dA. 运算符重载可以改变操作数的个数+ K( J5 C. n# Z5 z" C1 M
B. 运算符重载可以改变运算符的优先级1 }$ `( c! M& Q# n3 W; F
C. 运算符重载可以改变运算符的结合性
' ]5 A2 C3 p# d0 {6 H" rD. 运算符重载可以使运算符实现特殊功能
3 B) D7 p6 N( _5 { 满分:2 分
8 J* P1 E/ t" P( \2 y/ l15. 类MyClass的定义如下: class MyClass { public: MyClass() { value = 0;} SetVariable(int i) { value = i; } private: int value; } 则对下列语句序列正确的描述是()。 MyClass *p,my; p=&my;
; C- R0 ^2 q+ \" }A. 语句p=&my;是把对象my赋值给指针变量p7 L& \0 t; R" X& ]' c9 u. L
B. 语句MyClass *p,my;会调用两次类MyClass的构造函数: M& P' f2 x: T O# G6 ?: L' Y+ c
C. 对语句 *p.SetVariable(5)的调用是正确的2 l$ ?3 o- B7 k% W' w2 D
D. 语句p->SetVariable(5)与语句my.SetVariable(5)等价
' Q. J# C3 D& v D, G/ p 满分:2 分7 Y/ g# `8 c+ y$ o3 g* J; Z, Q
16. 运行以下程序时,如果由键盘输入65 14,则输出结果是()。 #include <iostream> using namespace std; int main() { int m, n; cout<<"Input m, n:"; cin>>m>>n; while(m!=n) { while(m>n) m-=n; while(n>m) n-=m; } cout<<m<<endl; return 0; }
; u# y; T+ I1 d/ n5 cA. 3' |, C: p8 g9 w! w% Y
B. 29 r9 o. `* }4 |/ q
C. 1: e; U6 g* P T( O: Z
D. 04 ~9 a( u" j6 l, t0 ]
满分:2 分
0 F! Z& J; Y# y7 M: w17. 在表达式x+y*z中,+ 是作为成员函数重载的运算符,*是作为非成员函数重载的运算符。下列叙述中正确的是()。, @! f. g7 p' Z6 G
A. operator+有两个参数,operator*有两个参数6 }- i. A9 f# Q$ K z, W
B. operator+有两个参数,operator*有一个参数
}4 {: v3 R; s" QC. operator+有一个参数,operator*有两个参数
! F7 z5 [- ^: f6 j3 dD. operator+有一个参数,operator*有一个参数
/ P* I$ h- z% e2 w) K 满分:2 分$ I3 q% ?2 i! j: y2 V
18. 若类中有指针成员变量,则应编写(),使得在对象销毁时能够自动调用该函数释放指针成员变量所指向的内存空间。. b7 ~% W: V" i3 \# b+ Z1 a
A. 友元函数
. q( {. e4 `% \B. 虚函数9 h1 x6 ~' n+ Z; x
C. 构造函数+ `5 C* P* E$ \8 g/ P' m
D. 析构函数
B# P4 Z4 o+ u# l4 Y. W/ E4 t2 r2 V 满分:2 分
) M+ F/ f( `* M4 u& e+ C1 Z19. 有如下类声明: class Sample { int x; }; 则Sample类成员x是Sample类的()。6 T, v. t$ ]0 m) T
A. 公有数据成员2 \3 {% Z1 ~) K9 l
B. 保护数据成员
5 \* L, ~& U# J9 q1 `C. 私有数据成员
/ x! T& f4 J: n( I, V' GD. 以上选项都不正确
4 t- S1 u3 Y/ M, w6 V' Q( D 满分:2 分; _2 l2 L" @* }( h
20. 下列关于拷贝构造函数的描述中,错误的是()。
/ K6 }1 ^ H' ]/ I. ~3 [8 {6 HA. 一个类可以定义多个拷贝构造函数" k! [, |( W; l4 Z
B. 若未定义拷贝构造函数,则系统会提供一个默认拷贝构造函数* n# f/ F& g, |4 N/ f; y% Q
C. 当类中有指针成员变量时,通常要为这个类定义一个拷贝构造函数来实现深拷贝
" _* v( i3 P7 v) u2 lD. 拷贝构造函数中的参数按引用方式传递
9 ?2 l0 w5 Q' y4 F 满分:2 分
0 l0 J z, T. m/ B$ O Z; `2 z21. 下列关于构造函数说法不正确的是()。
: ]+ P2 B7 u2 Z. YA. 构造函数必须与类同名
- L1 q+ {0 Z/ p C7 Z3 H2 mB. 构造函数可以省略不写
8 }$ o6 Y; U5 X" F/ ^C. 构造函数必须有返回值$ J8 I! B9 P9 R ^5 Y# I
D. 在构造函数中可以对类中的成员进行初始化
& m, D& K1 z7 d$ Q$ T 满分:2 分
) S1 f5 v$ b1 C+ J22. 要在类对象上使用运算符,以下不用必须被重载的运算符是()。
7 K _, ]3 e7 P8 t7 XA. [ ]
: \. d+ `. P5 D xB. =
5 d3 I, t) J- T: |9 pC. ++
6 m. ]) {) f; S. x% H6 WD. --! o# P- c& I+ S; ]
满分:2 分
5 ~7 {/ Q$ M- x7 x% H& O( Y23. 在一个string类对象表示的字符串中插入新字符,应该使用string类的()函数。" L, ]1 N" Q3 ^0 O% w" \; {6 D
A. assign' o) t: r) M; y0 z& p* T3 E/ _
B. insert
# M/ x( `" l* _" pC. swap
/ b7 a; F# a8 t+ F; KD. find W J X/ O" ?. Y7 J$ \
满分:2 分
! x1 B( y4 C( G. E, A24. 抽象类不能定义对象,但可以声明抽象类的()。
h. h: A0 f" _" M6 l6 J: J) YA. 指针或引用
$ k% h0 L5 z1 T3 hB. 函数返回类型) j1 J3 t: |& x' ^8 d( U
C. 显式转换/ h' O8 F; U8 V
D. 以上都是
# ?8 J/ O: m) j* ]' V 满分:2 分
% r# e) w( A P( B$ X9 g25. 下面关于构造函数和析构函数的描述,错误的是()。
- g; ?4 ^( w7 `9 UA. 析构函数中调用虚函数采用静态联编; E; L1 ?* E) F; `! l: p
B. 对虚析构函数的调用可以采用动态联编, I, [8 X& G4 V# h3 T
C. 当基类的析构函数是虚函数时,其派生类的析构函数也一定是虚函数- R9 z( Y' `/ r. _( \/ S! R7 F
D. 构造函数可以声明为虚函数1 k2 t- K6 |3 z: f: v
满分:2 分
/ @- L# `1 E" x26. 类的默认的无参构造函数()。
' ~% D) y0 ]6 |7 b4 }A. 在任何情况下都存在' y/ K8 {1 O, r$ j
B. 仅当未定义无参构造函数时存在0 c4 n$ I' l: L5 f. @4 d
C. 仅当未定义有参构造函数时存在' P) _. e& f" z p( Z2 A* {
D. 仅当未定义任何构造函数时存在8 r! h# b8 n6 g$ ?9 O8 ~
满分:2 分" S8 ]2 S! S6 m. ~
27. 下面描述中,错误的是()。
7 `( s: o. u. I5 s! N( K" ?A. 公有继承时,基类中的public成员在派生类中仍是public的
% I5 r1 t& `) z- f5 Z; x7 pB. 公有继承时,基类中的private成员在派生类中仍是private的0 @; N7 g( w, S8 B
C. 公有继承时,基类中的protected成员在派生类中仍是protected的: Z2 ]9 H. _, i3 d: \' W
D. 私有继承时,基类中的public成员在派生类中是private的
7 y+ b* w' ]7 Y, L8 _/ }$ ] 满分:2 分
& N+ F4 G5 J8 @3 e% X' v; T9 V28. 将一个函数声明为某类的友元函数后,则在函数中不可以直接访问该类的()。% @- C6 g6 W; B, N N
A. 公有成员
& N% o. K! a7 q' e' w# JB. 私有成员: l1 b8 w3 r( u+ A/ B" \
C. 保护成员7 A) p. ]" L! `, U2 J
D. 都可访问! P! b. A S( q* g0 W
满分:2 分
7 H& y1 z$ m/ v; K! B4 I# F; E% k29. 在公有派生情况下,有关派生类对象和基类对象的关系,下列叙述不正确的是()。
* J. k# O' l. QA. 派生类的对象可以直接访问基类的所有成员
E' S" p! B7 q, e+ j) sB. 派生类的对象可以初始化基类的引用! n- V4 z2 e3 S5 E1 H+ Y7 i
C. 派生类的对象不可以直接访问基类中的私有成员/ T5 J! \- N/ V4 j
D. 派生类的对象的地址可以赋给指向基类的指针
: q X* _ K3 p& r2 ] 满分:2 分
3 }! G$ {/ v/ X# B; c7 h- U% T0 t, I2 o30. 以成员函数方式重载运算符“>”,则obj1>obj2被C++编译器解释为()。- }# S3 R* y' p
A. operator>(obj1,obj2)+ n; v7 r9 G: e: A
B. >(obj1,obj2)6 s. P2 [' l+ m: w/ Q6 U
C. obj1.operator>(obj2)
! C, }6 p2 K# H! Z5 L+ {9 X* j6 P% ?( eD. obj2.operator>(obj1)
7 Q) p9 h* d9 C- U 满分:2 分6 g2 }$ b. Z. o4 z N# j
31. 有关重载函数的描述正确的是()。: N+ O4 G: @7 t; \: |" Q
A. 函数名相同的函数就是重载函数
; }6 k8 l& ^& l _; cB. 函数名相同但返回值类型不同的函数就是重载函数
$ S& a) ]! G0 X" F7 V6 O- n$ ]C. 函数名相同但参数个数或类型不同的函数就是重载函数
* P+ t+ d9 F* mD. 函数功能相同的函数就是重载函数/ ^) e f/ n8 a1 e5 T
满分:2 分
/ F$ c% T | f" ]+ p- G/ R32. 下列关于类和对象的叙述中,错误的是()。
H5 T4 J6 `/ M& O7 wA. 一个类只能有一个对象
; ]: \+ U# G1 @3 HB. 对象是类的具体实例
2 R: ~5 R9 c; T' W, uC. 类是某一类对象的抽象$ L0 l& G/ E) T' K9 C. s/ J( ~
D. 类和对象的关系是一种数据类型与变量的关系* E/ w$ ?& x$ W8 M5 C
满分:2 分+ w1 }" q7 U, v& E+ e
33. 对于拷贝构造函数,正确的描述是()。( w& M7 o1 H; V9 p$ _- Y
A. 在C++语言中,如果不自定义类的拷贝构造函数,则每个类都有默认的拷贝构造函数& Q2 z( n9 ]; r, @
B. 必须为每个类定义拷贝构造函数
9 ?- [* k- ^ Q. vC. 如果要使用拷贝构造函数,则必须在类中先定义
4 f+ W. x( N/ m- R1 q2 ~4 t7 [D. 当定义了类的构造函数时,如果要使用拷贝构造函数,则必须定义拷贝构造函数$ E+ X. w: @* b
满分:2 分
$ c% }+ n2 E, E k! _ z4 x& U% h: o; H34. 假定MyClass为一类,执行MyClass a,b(2),*p[2];语句时会自动调用该类构造函数()次。
, S! }7 _! V4 ^5 {% s: B+ |; u8 P& qA. 2
p8 x- Q& P9 R' R4 iB. 3
G) z& L% a. f; lC. 4& |# \% v. Z6 X' [# H5 @; p- @& ^: X
D. 5) U7 O+ a! Y2 q
满分:2 分
* H, O" J5 b/ Z, K) o A: U2 }35. 下列运算符中,()在C++中不能重载。( h5 I% z9 X0 Q# \4 _, q
A. ?:- Z0 }5 G y) E! @2 w
B. +9 Y3 w( G5 P9 a0 F! G
C. -% F( T( ]+ h3 q: I, I, y: N7 T
D. <=
. c4 |& M3 U3 F9 W 满分:2 分
; y) u1 y& i% f% t
( e- Z' p% i% w5 U6 z二、判断题(共 15 道试题,共 30 分。)V 1. a为MyClass类对象,“static void SetRate(double r){...}”是MyClass类的静态成员函数,则执行语句“a.SetRate(0.05);”时,SetRate成员函数中的this指针指向对象a的地址。
7 w" F8 ^6 I0 _$ H" {0 Q# ]A. 错误3 f3 e# W B5 s* U: }9 y' k
B. 正确1 t/ k8 w) b0 D3 \! V$ B3 v, G9 C' I- L
满分:2 分
. s! _" G- Y6 C# D$ T2. 私有继承中,对于基类中的所有成员,派生类的成员函数都不可直接访问。" q) P U' r0 K+ z0 S3 c: H$ K0 v }6 C- {
A. 错误
" I) O5 J* u& T5 Y( ?B. 正确! ?# A. R9 H' U5 o! w7 C
满分:2 分
; d! y) [: [% Z6 i z- E; G7 b0 V3. 要使语句“MyClass a;”能够编译通过,必须在定义MyClass类时编写无参构造函数。
2 X& K1 D" h& HA. 错误8 {+ c# }) g& n2 X- `4 V
B. 正确
* N& P; t! L. W8 P 满分:2 分
' ]4 t7 q; A& T: K% s8 ~! D$ Z4. 类中所提供的成员函数可以直接访问该类的私有成员。
% X7 i1 b4 M4 n2 yA. 错误
4 g. f+ Y, f6 E3 l) N) v. ^B. 正确
9 T! {1 m2 s [' ` [7 c4 Z, k4 B 满分:2 分7 m; ?4 J. K- n& T* N; ]) h* T
5. 在C++程序中,有且仅能有一个主函数,且其函数名必须是main。; `6 ~* | _: B. ~" `) {
A. 错误% l* m5 ~) t) \; M
B. 正确
$ S( Y3 l! X+ E3 E) j8 W 满分:2 分9 A. a0 U" b' O4 i& Z* @+ Z3 K
6. 定义一个虚基类后,则该虚基类后继类层次中的类都需要调用虚基类的构造函数对虚基类中定义的成员变量进行初始化。" K" f8 x: O2 l1 }) _ \* ^
A. 错误
* L- s; y& T) yB. 正确8 R. p: m: B* i" r8 e
满分:2 分
5 ^( p8 a( y1 m" A7. 抽象类不能定义对象,但可以声明抽象类的指针或引用。
$ C! k H/ v; M+ K8 IA. 错误
' d5 @% ]" j3 ]9 H0 AB. 正确7 D( z( `5 W8 ^8 ?
满分:2 分
' p+ I, n+ F* J, e- _% F' ~+ d, x$ X# o8. 基类类型的指针可以指向其派生类对象。4 f3 @) C- F- [# a& o3 y
A. 错误. u9 c B: L3 y
B. 正确' M6 j+ Z: T2 ^; T
满分:2 分* q' }# Q* `5 A8 ^( ~; x6 T
9. 在一个类中声明了某个静态数据成员,并在类外给出其定义和初始化后,若未定义该类的对象,该静态数据成员则不存在。8 B# u) A, C. u+ ?0 Z: v$ `
A. 错误9 z, J, X& k* Y4 ~( G, Q
B. 正确
% _ ?2 {! ~/ c7 c 满分:2 分
; L: C' Z+ n" ]3 p( y10. 以友元方式重载运算符时,形参列表中至少有一个参数必须是自定义数据类型。8 a7 |! m% t" D Z# h0 Z$ I6 J# n8 r% J
A. 错误
( Z1 T0 W! Z; \, zB. 正确
& u+ K- x* R: u0 L- B. b7 r, j) \ 满分:2 分" U, }7 t! j5 y, @
11. 在派生类对象销毁时,系统除了会自动调用派生类的析构函数,还会自动调用基类的析构函数。/ y7 t/ @3 e6 e' W$ V! I
A. 错误, Y- d) D4 d! n, g' W% X
B. 正确" q( |" A5 l% T; H, z# R, W
满分:2 分
: }6 ~% S$ C8 ^6 G8 s( r12. 在C++中,可以声明虚构造函数和虚析构函数。
# j: w0 V& n6 S" c6 k- wA. 错误
9 q5 {8 d0 [. |$ S1 DB. 正确
+ T$ V8 T* `' d 满分:2 分
5 q6 j& k% b5 m13. 派生类至少有一个基类。
, z! a) X" y% X* r- S3 B) ~& _A. 错误
* q) o8 z. l. P1 W1 b; S2 oB. 正确
6 Q# W0 U- o9 J3 v2 I 满分:2 分! H9 _0 w/ m$ u7 C3 J
14. 对虚函数的调用,系统都是采用动态联编。6 M7 @1 R$ B( L; x
A. 错误
* U& G+ C" ^/ p* x: g0 m4 S# fB. 正确; s! {9 O6 |) u
满分:2 分# i! B" r$ R! t s# O, J- M
15. 抽象类虽然也是一种数据类型,但它不能建立对象,只能作为基类被其他类继承。' H2 u+ `5 S+ m$ a0 W3 z
A. 错误+ ~; H0 L* x+ a1 F% Z
B. 正确
3 g' Q% g& X/ \2 | 满分:2 分
1 s$ ]3 |# w2 N; {' u% ] w3 s) J
! }! F; Y0 p. y& Y" w. { X谋学网: www.mouxue.com 主要提供奥鹏辅导资料,奥鹏在线作业辅导资料,奥鹏离线作业辅导资料和奥鹏毕业论文以及其他各远程教育作业代写服务,致力打造中国最专业远程教育辅导社区。% c% w1 Y8 u( @" h
|
|