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 10
typedef 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,表示再次查找最大值时该元素将被排除在外。