24344
备注:
|
24546
|
删除的内容标记成这样。 | 加入的内容标记成这样。 |
行号 543: | 行号 543: |
找出以下程序中的错误,并作出解释。一个程序可能有多个错误。如果没有错误,请注明程序正确。(每小题3分,共30分) | = 找出以下程序中的错误,并作出解释 = |
行号 545: | 行号 545: |
{{{#!cplusplus | |
行号 553: | 行号 553: |
}}} | |
行号 564: | 行号 564: |
{{{#!cplusplus | |
行号 592: | 行号 592: |
}}} | |
行号 606: | 行号 606: |
{{{#!cplusplus | |
行号 625: | 行号 625: |
}}} | |
行号 638: | 行号 638: |
{{{#!cplusplus | |
行号 648: | 行号 648: |
}}} | |
行号 659: | 行号 659: |
{{{#!cplusplus | |
行号 697: | 行号 697: |
}}} | |
行号 708: | 行号 708: |
{{{#!cplusplus | |
行号 738: | 行号 738: |
}}} | |
行号 749: | 行号 749: |
{{{#!cplusplus | |
行号 763: | 行号 763: |
}}} | |
行号 773: | 行号 773: |
{{{#!cplusplus | |
行号 807: | 行号 807: |
}}} | |
行号 819: | 行号 819: |
{{{#!cplusplus | |
行号 837: | 行号 837: |
}}} | |
行号 847: | 行号 847: |
{{{#!cplusplus | |
行号 889: | 行号 889: |
}}} | |
行号 898: | 行号 898: |
读程序,写出程序运行的结果(每小题3分,共30分) | = 读程序,写出程序运行的结果 = |
行号 900: | 行号 900: |
{{{#!cplusplus | |
行号 918: | 行号 918: |
}}} | |
行号 932: | 行号 932: |
{{{#!cplusplus | |
行号 946: | 行号 946: |
}}} | |
行号 960: | 行号 960: |
{{{#!cplusplus | |
行号 982: | 行号 982: |
}}} | |
行号 1001: | 行号 1001: |
{{{#!cplusplus | |
行号 1021: | 行号 1021: |
}}} | |
行号 1038: | 行号 1038: |
{{{#!cplusplus | |
行号 1070: | 行号 1070: |
}}} | |
行号 1081: | 行号 1081: |
{{{#!cplusplus | |
行号 1123: | 行号 1123: |
}}} | |
行号 1136: | 行号 1136: |
{{{#!cplusplus | |
行号 1160: | 行号 1160: |
}}} | |
行号 1173: | 行号 1173: |
{{{#!cplusplus | |
行号 1227: | 行号 1227: |
}}} | |
行号 1238: | 行号 1238: |
{{{#!cplusplus | |
行号 1274: | 行号 1274: |
}}} | |
行号 1289: | 行号 1289: |
{{{#!cplusplus | |
行号 1305: | 行号 1305: |
}}} | |
行号 1318: | 行号 1318: |
程序填空题,按要求填写程序(每空2分,共20分) | = 程序填空题,按要求填写程序 = |
行号 1320: | 行号 1320: |
{{{#!cplusplus | |
行号 1376: | 行号 1376: |
}}} | |
行号 1402: | 行号 1402: |
{{{#!cplusplus | |
行号 1461: | 行号 1461: |
}}} | |
行号 1466: | 行号 1466: |
编程题,按要求编写程序(每小题10分,共20分) | = 编程题,按要求编写程序 = |
行号 1475: | 行号 1475: |
{{{#!cplusplus | |
行号 1499: | 行号 1499: |
}}} | |
行号 1506: | 行号 1505: |
{{{#!cplusplus | |
行号 1509: | 行号 1507: |
行号 1511: | 行号 1508: |
行号 1515: | 行号 1511: |
行号 1517: | 行号 1512: |
行号 1519: | 行号 1513: |
行号 1553: | 行号 1546: |
}}} |
找出以下程序中的错误并作出解释
- 输出hello, world并换行
- 打印华氏温度与摄氏温度的对照表,输出摄氏度保留一位小数
- 单词计数
1 #include <stdio.h> 2 enum STATUS{IN, OUT}; 3 main() { 4 int c, state; 5 int nl = nw = nc = 0; 6 while( c = getchar() != EOF) { 7 ++nc; 8 if(c == "\n") ; 9 ++nl; 10 if(c == ' ' && c == '\n' && c == '\t') 11 state = OUT; 12 else if(state = OUT) 13 state = IN; 14 ++nw; 15 } 16 printf("%d %d %d\n", nl, nw, nc); 17 }
- 求指数
- 读取字符串并求字符串长度
1 #include <stdio.h> 2 int strlen(char s) 3 { 4 int i = 0; 5 while(s[++i] != '0') ; 6 return i; 7 } 8 int getline(char s, int lim) 9 { 10 int c, i; 11 for (i = 0; i < lim-1; ++i) { 12 if( (c = getchar()) != EOF && c!='\n') 13 s[i] = c; 14 else 15 brake; 16 if (c == '\n') 17 s[++i] = c; 18 s[i] = '\0'; 19 return i; 20 } 21 main() 22 { 23 char s[]; 24 int len; 25 getline(s, 1000); 26 len = strlen(s); 27 printf("%d:%s", len, s); 28 }
- 栈的数据定义和操作
1 #define MAXVAL 100; 2 extern int sp = 0; 3 double val[MAXVAL]; 4 void push(double f) { 5 if(sp < MAXVAL) 6 val[++sp] = f; 7 else 8 printf("error: stack full"); 9 } 10 double pop(void) { 11 if(sp >= 0) 12 return val[--sp]; 13 else { 14 printf("error: stack empty"); 15 return 0.0; 16 } 17 } 18 19 main() { 20 int i; 21 for(i = 0; i < 5; i++) 22 push(i); 23 for(i = 0; i < 5; i++) 24 printf("%f", pop(i)); 25 }
- 递归函数打印一个整数
- 读取整数的函数
1 #include <ctype.h> 2 #include <stdio.h> 3 char buf[BUFSIZE]; 4 int bufp = 0; 5 int getch(void); /*从输入流读取一个字符*/ 6 { 7 return (bufp>0)?buf[--bufp]:getchar(); 8 } 9 void ungetch(int c); /*将一个字符放回输入流*/ 10 { 11 if(bufp >= BUFSIZE) 12 printf("ungetch: too many char\n"); 13 else 14 buf[bufp++] = c; 15 } 16 int getint(int *pn) 17 { 18 int c, sign; 19 while(isspace( getch())); 20 if(!isdigit(c) && c != EOF && c!='+' && c!='-') { 21 ungetch(c); 22 return 0; 23 } 24 sign = c == '-' ? -1 : 1; 25 if( c == '+' || c == '-') 26 c = getch(); 27 for( pn = 0; isdigit(c); c = getch()) 28 pn = 10 * pn + c – '0'; 29 pn *= sign; 30 if(c != EOF) 31 ungetch(c); 32 return c; 33 }
读程序,写出程序运行的结果
1 #include <stdio.h> 2 void selectsort(int v[], int n) { 3 int i, j, min, temp; 4 for( i = 0; i < n-1; i++) { 5 min = i; 6 for( j = i + 1; j < n; j++) 7 if(v[j] < v[min]) 8 min = j; 9 temp = v[min]; 10 v[min] = v[i]; 11 v[i] = temp; 12 } 13 } 14 int main() { 15 int i; 16 int s[] = { 5, 4, 3, 2, 1}; 17 selectsort(s, 5); 18 for(i = 0; i < 5; i++) 19 printf("%3d", s[i]); 20 }
- 假定int, unsigned是32位的。
1 #include <stdio.h> 2 #define MAXVAL 10 3 int queue[MAXVAL]; 4 int front = 0; 5 int back = 0; 6 int empty() { 7 return front == back; 8 } 9 int full() { 10 return (back + 1)%MAXVAL == front; 11 } 12 int size() { 13 return (back - front + MAXVAL) % MAXVAL; 14 } 15 void enqueue(int v) { 16 if(full()) 17 return; 18 queue[back++] = v; 19 back = back % MAXVAL; 20 } 21 int dequeue() { 22 int v; 23 if( empty() ) 24 return 0; 25 v = queue[front++]; 26 front = front % MAXVAL; 27 return v; 28 } 29 main() { 30 int i; 31 for(i = 1; !full(); i++) 32 enqueue(i); 33 print("%d\n", size()); 34 while(!empty()) 35 printf("%d\n", dequeue()); 36 }
1 #include <stdio.h> 2 #include <ctype.h> 3 int stricmp(char s[], char t[]) { 4 int i; 5 for( i = 0; s[i] != '\0' && t[i] != '\0'; i++) 6 if(tolower(s[i]) != tolower(t[i])) 7 break; 8 return tolower(s[i]) - tolower(t[i]); 9 } 10 main() { 11 char s1[] = { 'a', 'b', 'c', 'd', '\0'}; 12 char s2[] = "ABCD"; 13 char s3[] = "abcde"; 14 int s1s2 = stricmp(s1, s2); 15 int s2s3 = stricmp(s2, s3); 16 printf("%s is %s %s\n", s1, s1s2==0 ? "equal to" : s1s2 > 0 ? "great than" : "less than" , s2); 17 printf("%s is %s %s\n", s2, s2s3==0 ? "equal to" : s2s3 > 0 ? "great than" : "less than" , s3); 18 }
编程题,按要求编写程序
- 分别编写递归方式和非递归方式的reverse(s)函数,用于将字符串s倒过来
- 分别编写递归方式和非递归方式的fact(n)函数,用于计算n的阶乘n!
- 分别编写递归方式和非递归方式的combination(m, n),用于计算组合数
- 写一个程序统计输入的空格数,tab数,和换行数。
- 编写一个程序,把输入拷贝到输出,把其中连续的多个空格替换成一个空格。
- 编写一个程序,把输入中长度超过80个字符的行输出。
- 编写一个程序,把输入中每一行末尾的空格或者tab删除。
- 编写一个程序,将输入中的水平制表符替换成适当数目的空格,使空格充满到下一个制表符终止位。假设制表符终止位的位置是固定的,每隔10列就会出现一个制表符终止位。
- 编写一个程序,把超过50个字符的输入行折成短一些的两行或多行,折行的位置在输入行的第50、100、150……列的位置。
- 编写一个程序,把输入拷贝到输出,并替换退格符为\b,替换其中的tab为\t,替换反斜杠为\\,使得原来不可见的字符变得可见。
读程序,写出程序运行的结果
1 #include <stdio.h> 2 #include <math.h> 3 #define FALSE 0 4 #define TRUE 1 5 #define BOOL int 6 7 BOOL prime(int a) { 8 int i; 9 for( i = 2; i <= sqrt((double)a); i++) 10 if( a % i == 0) 11 return FALSE; 12 return TRUE; 13 } 14 main() { 15 int x = 37, y = 91; 16 printf("%d\n%d", prime(x), prime(y)); 17 }
1 #include <stdio.h> 2 3 main() { 4 int flag = 0; 5 int count = 0; 6 int c; 7 while( (c = getchar()) != EOF ) { 8 if(flag == 0) { 9 if(c =='c') 10 flag ++; 11 } 12 else if( flag == 1) { 13 if( c == 'z') 14 flag ++; 15 else 16 flag = 0; 17 } 18 else if( flag == 2) { 19 if( c == 'k') 20 count ++; 21 flag = 0; 22 } 23 } 24 printf("%d", count); 25 }
程序运行后输入czk loves c programming language! czk programs every day!
1 #include <stdio.h> 2 enum months{JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV, DEC}; 3 main() { 4 int days[12]; 5 int i; 6 days[JAN] = 31; 7 days[FEB] = 28; 8 days[MAR] = 31; 9 days[APR] = 30; 10 days[MAY] = 31; 11 days[JUN] = 30; 12 days[JUL] = 31; 13 days[AUG] = 31; 14 days[SEP] = 30; 15 days[OCT] = 31; 16 days[NOV] = 30; 17 days[DEC] = 31; 18 for( i = JAN; i <= DEC; ++i) { 19 printf("month %6d has %6d days\n", i, days[i]); 20 } 21 }
1 #include <stdio.h> 2 enum BOOL {FALSE, TRUE}; 3 int isdigit(int c) { 4 return c >='0' && c<='9'; 5 } 6 int islower(int c) { 7 return c >='a' && c<='z'; 8 } 9 int isupper(int c) { 10 return c >='A' && c<='Z'; 11 } 12 int isalpha(int c) { 13 return isupper(c) || islower(c); 14 } 15 int isspace(int c) { 16 return c=='\n' || c=='\t' || c==' ' || c=='\r' || c=='\v' || c=='\f'; 17 } 18 int isxdigit(int c) { 19 return isdigit(c) || (c>='a' && c <='f') || (c>='A' && c<='F'); 20 } 21 int isalnum(int c) { 22 return isalpha(c) || isdigit(c); 23 } 24 main() { 25 int c; 26 while( (c = getchar())!=EOF) { 27 printf("%2d%2d%2d%2d%2d%2d%2d\n", isdigit(c), islower(c), isupper(c), 28 isalpha(c), isspace(c), isxdigit(c), isalnum(c)); 29 } 30 }
输入(共计7个字符):b =0XF;
按要求编写程序
- 写一个函数reverse(s),将字符串s反转。比如
char s[]="hello"; reverse(s);
这时s变成"olleh" - 写一个函数invert(x,p,n),这个函数将整数x从右数第p位开始的n位反转(0变1,1变0),并将这个值返回。比如:invert(0x72, 4, 3)将返回0x6E.
- 请写一个程序分别统计输入当中空格、水平制表符(tab)和换行符(newline)的个数,即程序运行后输入任意一些字符,以Ctrl+Z结束输入,程序输出这些字符中空格的个数、水平制表符的个数以及换行符的个数。
找出以下程序中的错误,并作出解释
- 输出hello, world并换行
第一行漏了#,应该是#include <stdio.h>
/n应该改成\n
printf语句后面漏了;
- 打印华氏温度与摄氏温度的对照表,输出摄氏度保留一位小数
step没有赋初值
fahr是整数,格式化串应该对应的%3d而不是%3.0f
5*(fahr - 32)/9为整数,没有保留小数部分,应改为5.0*(fahr - 32.0) / 9.0
- 打印华氏温度与摄氏温度的对照表,输出摄氏度保留一位小数
#define宏后面不要有分号
for的三个字句应该用;分开,而不能用,隔开
(5.0/9.0)和(fahr-32)之间应该有*
- 把输入字符复制到输出
main函数后面应该有()
while条件应该为(c=getchar())!=EOF
变量c没有定义,应该定义为int c;
- 单词计数
1 #include <stdio.h>
2
3 #define OUT 1
4
5 #define IN 0
6
7 main() {
8
9 int c, state = OUT;
10
11 int nl = nw = nc = 0;
12
13 while((c=getchar()) != EOF) {
14
15 ++nc;
16
17 if(c == '\n')
18
19 ++nl;
20
21 if(c == ' ' && c == '\n' && c == '\t')
22
23 state = OUT;
24
25 else if(state = OUT) {
26
27 state = IN;
28
29 ++nw;
30
31 }
32
33 }
34
35 printf("%d %d %d\n", nl, nw, nc);
36
37 }
int nl = nw = nc = 0;是错误的,应该写为int nl = 0, nw = 0, nc = 0;
c == ' ' && c == '\n' && c == '\t'应该改为c == ' ' || c == '\n' || c == '\t'
state = OUT应该改为state == OUT
- 求指数
1 #include <stdio.h>
2
3 main() {
4
5 int i;
6
7 for(i = 0; i < 10; i++)
8
9 printf("%d %f %f\n",i, power(float 2.0f, int i), power(float -3.0f,int i));
10
11 return 0;
12
13 }
14
15 float power(base, n)
16
17 {
18
19 int i;
20
21 float p = 1.0f;
22
23 for(i = 1; i <= n; ++i)
24
25 p *= base;
26
27 return p;
28
29 }
函数power缺少声明
power函数调用的时候参数错误
power函数定义base和n缺少参数
- 求字符串长度的函数
'0'应该改为'\0'
- 栈的数据定义和操作
1 #define MAXVAL 100
2
3 extern int sp = 0;
4
5 double val[MAXVAL];
6
7 void push(double f) {
8
9 if(sp < MAXVAL)
10
11 val[++sp] = f;
12
13 else
14
15 printf("error: stack full");
16
17 }
18
19 double pop(void) {
20
21 if(sp >= 0)
22
23 return val[--sp];
24
25 else {
26
27 printf("error: stack empty");
28
29 return 0.0;
30
31 }
32
33 }
extern声明变量sp的时候不能赋初值
push函数当中val[sp++] = f;
- 递归函数打印一个整数
printd(n/10);语句前应该加上if(n/10)
- 读取整数的函数(getch函数和ungetch函数的定义省略)
1 #include <ctype.h>
2
3 int getch(void); /*从输入流读取一个字符*/
4
5 void ungetch(int); /*将一个字符放回输入流*/
6
7 int getint(int *pn)
8
9 {
10
11 int c, sign;
12
13 while(isspace(c = getch()));
14
15 if(!isdigit(c) && c != EOF && c!='+' && c!='-') {
16
17 ungetch(c);
18
19 return 0;
20
21 }
22
23 sign = c == '-' ? -1 : 1;
24
25 if( c == '+' || c == '-')
26
27 c = getch();
28
29 for( *pn = 0; isdigit(c); c = getch())
30
31 pn = 10 * pn + c – '0';
32
33 *pn *= sign;
34
35 if(c != EOF)
36
37 ungetch(c);
38
39 return c;
40
41 }
pn = 10 * pn + c – '0';应该改为*pn = 10 * *pn + c - '0';
读程序,写出程序运行的结果
- 程序
结果:
2
1
- 程序
结果
- 2.0
- -1.0
- 程序
结果:
Year 1995 is nonleap year
Year 1996 is leap year
Year 1997 is nonleap year
Year 1998 is nonleap year
Year 1999 is nonleap year
Year 2000 is leap year
- 程序
结果:
count called for 1 times
count called for 2 times
count called for 3 times
count called for 4 times
count called for 5 times
- 程序
1 #include <stdio.h>
2
3 #include <ctype.h>
4
5 int stricmp(char s[], char t[]) {
6
7 int i;
8
9 for( i = 0; s[i] != '\0' && t[i] != '\0'; i++)
10
11 if(tolower(s[i]) != tolower(t[i]))
12
13 break;
14
15 return tolower(s[i]) - tolower(t[i]);
16
17 }
18
19 main() {
20
21 char s1[] = { 'a', 'b', 'c', 'd', '\0'};
22
23 char s2[] = "ABCD";
24
25 char s3[] = "abc";
26
27 printf("%s and %s are %s equal\n", s1, s2, (stricmp(s1, s2)==0) ? "" : "not");
28
29 printf("%s and %s are %s equal\n", s2, s3, (stricmp(s2, s3)==0) ? "" : "not");
30
31 }
结果:
abcd and ABCD are equal
ABCD and abc are not equal
- 程序
1 #include <stdio.h>
2
3 #define MAXVAL 10
4
5 int queue[MAXVAL];
6
7 int front = 0;
8
9 int back = 0;
10
11 void enqueue(int v) {
12
13 queue[back++] = v;
14
15 back = back % MAXVAL;
16
17 }
18
19 int dequeue() {
20
21 int v = queue[front++];
22
23 front = front % MAXVAL;
24
25 return v;
26
27 }
28
29 main() {
30
31 int i;
32
33 for(i = 1; i <= 3; i++)
34
35 enqueue(i);
36
37 for(i = 0; i < 3; i++)
38
39 printf("%d\n", dequeue());
40
41 }
结果:
1
2
3
- 程序(此题中假定int和unsigned为32位)
结果
2
28
24
- 程序
1 #include <stdio.h>
2
3 int weekday(int year, int month, int day) {
4
5 int y, c;
6
7 if(month == 1 || month == 2) {
8
9 month += 12;
10
11 year--;
12
13 }
14
15 y = year % 100;
16
17 c = year / 100;
18
19 return (y + y/4 + c / 4 - 2 * c + 26*(month+1) / 10 + day -1) % 7;
20
21 }
22
23 int main() {
24
25 int year = 2005;
26
27 int month = 12;
28
29 int day = 25;
30
31 printf("%d\n", weekday(year, month, day));
32
33 switch(weekday(year, month, day)) {
34
35 case 1: case 2: case 3: case 4: case 5:
36
37 printf("this is a work day\n");
38
39 break;
40
41 case 6: case 0:
42
43 printf("this is not a work day\n");
44
45 break;
46
47 default:
48
49 printf("this day does not exist\n");
50
51 }
52
53 }
结果:
0
this is not a work day
- 程序
1 #include <stdio.h>
2
3 void bubblesort(int v[], int n) {
4
5 int i, j;
6
7 for( i = n-1; i >= 0; i--)
8
9 for(j = 0; j < i; j++)
10
11 if(v[j] > v[j+1]) {
12
13 int temp = v[j];
14
15 v[j] = v[j+1];
16
17 v[j+1] = temp;
18
19 }
20
21 }
22
23 int main() {
24
25 int i;
26
27 int s[] = { 5, 4, 3, 2, 1};
28
29 bubblesort(s, 5);
30
31 for(i = 0; i < 5; i++)
32
33 printf("%3d", s[i]);
34
35 }
结果
- 1 2 3 4 5
- 程序
结果
6
8
程序填空题,按要求填写程序
- 打印输入的单词长度的直方图
1 #include <stdio.h>
2
3 #define MAXLENGTH 20
4
5 main() {
6
7 int c, i, len, max, nlength[MAXLENGTH+1];
8
9 for(i = 0; i <= MAXLENGTH; i++)
10
11 __nlength[i] = 0;__
12
13 max = 0;
14
15 len = 0;
16
17 while (__(c=getchar()) != EOF__) {
18
19 if( c != ' ' && c!= '\n' && c != '\t') {
20
21 ++len;
22
23 } else if(len != 0) {
24
25 if(len <= MAXLENGTH) {
26
27 __nlength[len]++;__
28
29 if(len > max)
30
31 max = len;
32
33 }
34
35 len = 0;
36
37 }
38
39 }
40
41 for(i = 1; __i <= max__; i++) {
42
43 int j = 0;
44
45 printf("length:%4d count:%4d ", i, nlength[i]);
46
47 for(j = 0; __j < nlength[i]__; j++)
48
49 putchar('=');
50
51 putchar('\n');
52
53 }
54
55 }
程序输入:
Write a program to print a histogram of the lengths of words in its input
程序输出结果:
length: 1 count: 2 ==
length: 2 count: 4 ====
length: 3 count: 2 ==
length: 4 count: 0
length: 5 count: 4 ====
length: 6 count: 0
length: 7 count: 2 ==
length: 8 count: 0
length: 9 count: 1 =
- 快速排序
1 #include <stdio.h>
2
3 void swap(int v[], int i, int j);
4
5 void qsort(int v[], int left, int right);
6
7 int main() {
8
9 int i;
10
11 int v[] = {15, 12, 31, 21 ,45};
12
13 qsort(__v, 0, 4__);
14
15 for(i = 0; i < 5; i++)
16
17 printf("%4d", v[i]);
18
19 }
20
21 void qsort(int v[], int left, int right) {
22
23 int i, last;
24
25 if(__left >= right__)
26
27 return;
28
29 swap(v, left, (left+right)/2);
30
31 last = left;
32
33 for(i = left + 1; i <= right; i++)
34
35 if(v[i] < v[left])
36
37 swap(v, ++last, i);
38
39 swap(v, left, last);
40
41 qsort(__v, left, last - 1__);
42
43 qsort(__v, last + 1, right__);
44
45 }
46
47
48
49
50 void swap(int v[], int i, int j) {
51
52 __int temp = v[i]__;
53
54 v[i] = v[j];
55
56 v[j] = temp;
57
58 }
程序输出结果
- 12 15 21 31 45
编程题,按要求编写程序
- 编写ackerman函数
编写一个ackerman函数,这个函数用于计算如下数学公式:
编写一个main函数计算并输出A(3, 4)的值
- 编写一个程序,将输入中的水平制表符替换成适当数目的空格,使空格充满到下一个制表符终止位。假设制表符终止位的位置是固定的,每隔10列就会出现一个制表符终止位。
1 #include<stdio.h>
2 #include<stdlib.h>
3 #define TABSIZE 10
4
5 main()
6 {
7 int c, i;
8 int count = 0;
9
10 while((c=getchar())!=EOF) {
11
12 if(c=='\t') {
13
14 int space = TABSIZE - count % TABSIZE;
15
16 for(i = 0; i < space; i++) {
17
18 putchar(' ');
19
20 count ++;
21
22 }
23
24 } else if (c == '\n'){
25
26 putchar(c);
27
28 count = 0;
29
30 } else {
31
32 putchar(c);
33
34 count ++;
35
36 }
37
38 }
39
40 }