C语言程序设计之基础易错题锦集2
C语言程序设计之基础易错题锦集2
- 自加自减
- 代码2_0_1
- 运行结果2_0_1
- 代码2_0_2
- 运行结果2_0_2
- 问题2_1
- 解答2_1
- 问题2_2
- 结果2_2
- 问题2_3
- 结果2_3
- 问题2_4
- 结果2_4
- 问题2_5
- 结果2_5
- 问题2_6
- 结果2_6
自加自减
代码2_0_1
#include<stdio.h>main(){int a,b,c,d;a=b=c=d=10;printf("%d\n", a++);printf("%d\n", ++b);printf("%d\n", c--);printf("%d\n", --d);
}
运行结果2_0_1
后缀:使用变量之后再自加或者自减;前缀:自加或自减之后再进行运算。
代码2_0_2
#include<stdio.h>main(){int n=2,k=0;while(k++&&n++>2);printf("%d %d\n", k, n);
}
运行结果2_0_2
没有进入while循环,故而自加没运行。
问题2_1
以下程序输出结果是?
#include<stdio.h>main(){double d=3.2;int x,y;x = 1.2;y = (x+3.8)/5.0;printf("%d", d*y);
}
解答2_1
首先程序先执行 x=1.2;根据赋值运算的类型转换规则,先将 double 型的常量 1.2 转换成 int 型,即取整为 1。然后将 1 赋给变量 x,接下来执行语句 y=(x+3.8)/5.0,结果为 0。于是变量 y 的值为 0,d*y 的值也为 0。
问题2_2
以下程序输出结果是?
#include<stdio.h>struct st{int x;int *y;
}*p;
int dt[4] = {10, 20, 30 ,40};
struct st aa[4] = {50, &dt[0], 60, &dt[0], 60, &dt[0], 60, &dt[0],};
main(){p = aa;printf("%d\n", ++(p->x));
}
结果2_2
问题2_3
以下程序输出的结果是?
#include<stdio.h>main(){char s[] = "012xy\08s34f4w2";int i, n=0;for(i=0; s[i]!=0; i++)if(s[i]>='0'&&s[i]<='9') n++;printf("%d\n", n);
}
结果2_3
问题2_4
以下程序输出的结果是?
#include<stdio.h>main(){int x=20;printf("%d ", 0<x<20);printf("%d\n", 0<x&&x<20);
}
结果2_4
问题2_5
以下程序输出的结果是?
#include<stdio.h>
#include<string.h>struct A{int a;char b[10];double c;
};struct A fun(struct A t){t.a = 1002;strcpy(t.b, "Shoudao");t.c = 1202.0;return t;
}main(){struct A a={1001, "Zhiyi", 1098.0};a = fun(a);printf("%d,%s,%6.1f\n", a.a, a.b, a.c);
}
结果2_5
问题2_6
函数的功能是:对 N 名学生的学习成绩,按从高到低的顺序找出前 m(m<=10)名学生,并将这些学生的数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。
#include<stdlib.h>
#include<conio.h>
#include<stdio.h>
#include<string.h>
#include<malloc.h>#define N 10typedef struct ss{char num[10];int s;
}STU;STU *fun(STU a[], int m){STU b[N], *t;int i, j, k;t = (STU*)calloc(m, sizeof(STU));for(i=0; i<N; i++)b[i] = a[i];for(k=0; k<m; k++){for(i=j=0; i<N; i++)if(b[i].s>b[j].s)j = i;strcpy(t[k].num,b[j].num);t[k].s = b[j].s;b[j].s = 0;}return t;
}outresult(STU a[], FILE*pf){int i;for(i=0; i<N; i++)fprintf(pf, "No=%s Mark=%d\n", a[i].num, a[i].s);fprintf(pf,"\n\n");
}void main(){STU a[N] = {{"A01", 81}, {"A02", 89}, {"A03", 66}, {"A04", 87}, {"A05", 77}, {"A06", 90},{"A07", 79}, {"A08", 61}, {"A09", 80},{"A10", 71}};STU *pOrder;int i, m;system("CLS");printf("***** THE RESULT *****\n");outresult(a, stdout);printf("\nGive the number of the students who have better score: ");scanf("%d", &m);while(m>10){printf("\nGive the number of the students who have better score: ");scanf("%d", &m);}pOrder = fun(a, m);printf("***** THE RESULT *****\n");printf("The top: \n");for(i=0; i<m; i++)printf("%s %d\n", pOrder[i].num, pOrder[i].s);free(pOrder);
}
结果2_6
(1) 在函数 fun 中,声明了一个结构体数组和一个结构体指针。数组 b 的作用是暂存数组 a 的数据,因为题目中会改变数组元素的值,所以不能直接在数组 a 中改动;结构体指针 t 的作用是指向一块存储区域,用于存放题目要求的前 m 个学生信息。此处在调用 calloc 函数分配 m 个 STU 结构体大小空间后,需要先把指针强制类型转换为 struct STU*,然后赋值给指针变量 t ,而不是 *t。
(2) 在双重 for 循环中,外层循环表示对指针 t 所指向的空间存储 m 个学生信息;内层循环和内嵌的选择语句,表示记录数组中 s 成员最大的数组元素的下标,然后把 num 成员和 s 成员存放最大的数组元素的下标,然后把 num 成员和 s 成员存放在 t 所指向的空间中,所以此处应调用字符串复制函数实现 num 成员的复制,接下来设置当前最大的数组的数组元素的 s 成员值为 0,表示再次查找最大值时该元素将被排除在外。