C语言程序设计之基础易错题锦集2

自加自减

代码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

Result_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

Resulr_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

Result_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

Result_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

Result_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

Result_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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值