[新]C语言期末复习,经典练习题+知识点总结+模拟考题 三位一体,完胜c语言!!!!考期必备神器 下载本文

[红色为采用答案

#include #include

struct point { int x;

int y; }A1,A2,B1,B2;

struct rect { struct point p1; struct point p2; }R1,R2;

struct point makepoint(int x,int y);

struct rect makerect(struct point p1,struct point p2);

struct rect guifanrect(struct rect R);

#define max(A,B) ((A)>(B)?(A):(B)) #define min(A,B) ((A)>(B)?(B):(A)) main() {

5 / 30

int i,num1[4],num2[4],area;

for(i=0;i<4;i++) scanf(\ for(i=0;i<4;i++) scanf(\

R1 = makerect(A1 =

makepoint(num1[0],num1[1]), A2 = makepoint(num1[2],num1[3]));

R2 = makerect(B1 =

makepoint(num2[0],num2[1]), B2 = makepoint(num2[2],num2[3]));

R1 = guifanrect(R1); R2 = guifanrect(R2);

if( R1.p2.x <= R2.p1.x || R1.p2.y <= R2.p1.y ||

R1.p1.x >= R2.p2.x || R1.p1.y >= R2.p2.y) area = 0; else

area = abs(max(R1.p1.x, R2.p1.x) - min(R1.p2.x, R2.p2.x)) *

abs(max(R1.p1.y, R2.p1.y) - min(R1.p2.y, R2.p2.y));

printf(\}

struct point makepoint(int x,int y) {

struct point temp; temp.x = x; temp.y = y; return temp; }

struct rect makerect(struct point p1,struct point p2) {

struct rect temp; temp.p1 = p1; temp.p2 = p2; return temp; }

struct rect guifanrect(struct rect r) {

struct rect temp;

temp.p1.x = min (r.p1.x, r.p2.x); temp.p1.y = min (r.p1.y, r.p2.y); temp.p2.x = max (r.p1.x, r.p2.x); temp.p2.y = max (r.p1.y, r.p2.y); return temp; }

6 / 30

3. 【问题描述】编写一个程序,当在一个字符串中出现子串时就删除它。

【输入形式】用户在第一行输入一个字符串,用户在第二行输入一个子串。

【输出形式】程序在下一行输出删除其中所有子串后的字符串。如果字符串不包含子串则输出原字符串本身。 【样例输入】 I am a boy! a 【样例输出】 I m boy!

【样例说明】用户首先输入字符串I am a boy!,然后输出子串a,程序会寻找字符串中的子串删除它,最后 将删除后的结果输出:I#m##boy! #表示空格。

【评分标准】结果完全正确得20分,每个测试点4分。提交程序名为:delsubstring.c。 #include #include char source_str[1024]; char del_str[1024]; char dest_str[1024];

int main( void ) {

char *pdest; int result;

fgets(source_str, 1024, stdin);

fgets(del_str, 1024, stdin);

source_str[strlen(source_str)-1] = '\\0'; del_str[strlen(del_str)-1] = '\\0';

pdest = strstr(source_str, del_str); result = 0;

while(pdest != NULL) {

strncat(dest_str, &source_str[result], (int)(pdest - &source_str[result])); result += (int)(pdest -

&source_str[result]) + strlen(del_str);

pdest = strstr(&source_str[result], del_str); }

if(result < strlen(source_str)) {

strncat(dest_str, &source_str[result], strlen(source_str) - result); }

printf(\ return 0; }

4. 【问题描述】

编写一个函数char * str_bin(char* str1, char* str2), str1、str2是两个有序字符串(其中字符按ASCII码从小到大排序),将str2合并到字符串str1中,要求合并后的字符串仍是有序的,允许字符重复。在main函数中测试该函数:从键盘输入两个有序字符串,然后调用该函数,最后输出合并后的结果。

7 / 30

【输入形式】

分行从键盘输入两个有序字符串(不超过100个字符) 【输出形式】

输出合并后的有序字符串 【输入样例】 aceg bdfh

【输出样例】 abcdefgh 【样例说明】

输入两个有序字符串aceg和bdfh,输出合并后的有序字符串abcdefgh 【评分标准】

结果完全正确得20分,每个测试点4分,提交程序文件名为combine.c。 #include

char * str_bin(char* str1, char* str2) {

static char str[100]; int i = 0;

while (*str1 && *str2) {

if (*str1 < *str2) str[i++] = *str1++; else

str[i++] = *str2++;

} if (*str1)

while (str[i++] = *str1++); else

while (str[i++] = *str2++); return str; }

int main () { char a[100]; char b[100];

scanf(\ printf (\ return 0; } 作业四

填空题

# 题目

1. 已知: int a=2, b=7; 计算下列表达式的值: 5

a=4,b=1,a>b?++a:++b;

选择题

# 题目 1. 已知:char a=’a’;float b=2.3;double c=41;int d;则执行语句d=a+b+c;后变量d的数据类型为 A

8 / 30

(A) int (B) char (C) float (D) double

2. 字符串“\\ta\\017bc”的长度(不包括结束符)是 C (A) 9 (B) 5 (C) 6

(D) 7

3. 设整型变量x和y的值均为7,则表达式“x/(y-4)”的值是C A. 3

B. -3 C. 2 D. 1

4. 题目内容: 有输入语句:int a,b,c; scanf(\&a, &b, &c); 为使变量a的值为1,b的值为3,c的值为2,

从键盘输入数据的正确形式应当是(注:#表示空格)D

(A) 132<回车> (B) 1,3,2<回车>

(C) a=1#b=3#c=2<回车> (D) a=1,b=3,c=2<回车> 编程题

作业四---反弹

1. 【问题描述】

已知一球从高空落下时,每次落地后反弹至原高度的四分之一再落下。编写一程序,从键盘输入整数n和m,求该球从n米的高空落下后,第m次落地时共经过的路程以及第m次落地后反弹的高度,并输出结果。 【输入形式】

从键盘输入整数n和m,以空格隔开。 【输出形式】 输出两行: