[红色为采用答案
#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
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,以空格隔开。 【输出形式】 输出两行: