《程序设计实践》第05练——指针Part(1/2)

本文档提供了多个编程练习,涉及使用指针处理三角形周长和面积、实数排序、整数排序、字符串排序以及寻找整数和结构体数组中的最大值等。每个练习都给出了输入输出样例和数据限制,要求使用地址传递和指针方法完成程序编写。
摘要由CSDN通过智能技术生成

《程序设计实践》第05练——指针Part(1/2)
注意:打开相关源程序后,只能在//********与//=======之间编写程序,若修改其它部分可能得0分。

  1. 函数参数传递——地址传递
    1.1. 学生模拟题:SC6_1B.cpp(本题15分)

【题目描述】 已知三角形的三条边的长度,求该三角形的周长和面积,如果三个边不能构成三角形,则三角形的周长和面积都为0。打开SC6_1B.cpp文件,完成程序的编写。

【输入】
输入文件SC6_1B.in有1行,包含3个实数,各实数之间用空格隔开。
【输出】
输出文件SC6_1B.out有1行,包含2个实数(用一个空格隔开),分别是三角形的周长和面积,结果保留2位小数,第3位小数四舍五入。
【输入输出样例1】
SC6_1B.in SC6_1B.out
5.968 5.123 7.63 18.72 15.26
【输入输出样例2】
SC6_1B.in SC6_1B.out
4.2 3.1 7.5 0.00 0.00
【数据限制】
所有数据均可用double类型表示。

#include "stdio.h"
#include "math.h"
void  lengthArea(double a, double b, double c, double *length, double *area ){
   //根据三角形三条边的长度,求该三角形的周长和面积
	//******************************************
	if(a+b<=c || a+c<=b || b+c<=a){
   //给定的三个边长-->不能构成三角形
		*length = 0;
		*area = 0;
	}else{
   
		double p=(a+b+c)/2.0;

		*length = a+b+c;					//三角形的周长
		*area = sqrt(p*(p-a)*(p-b)*(p-c));	//三角形的面积
	}

	//==========================================
}

int main(){
   
	double a, b, c, length, area;			//a,b,c-三角形三条边的长度; length-三角形周长;  area-三角形面积
	
	FILE *fp;
	if((fp=fopen("SC6_1B.in", "r")) != NULL ){
   
		fclose(fp);  //存在的话,要先把之前打开的文件关掉
		
		freopen("SC6_1B.in", "r", stdin);
		freopen("SC6_1B.out", "w", stdout);
	}
	
	scanf("%lf%lf%lf", &a, &b, &c);			//输入(接收)三角形的三边长
	//******************************************
	//(1)进行函数调用
	lengthArea(a,b,c, &length, &area);
	
	//(2)输出三角形的周长和面积
	printf("%.2lf %.2lf\n", length, area);	
	//==========================================
	return 0;
}

1.2. 拓展题:SC6_1C.cpp(本题15分)

【题目描述】 输入三个实数,从小到大输出该三个实数。打开SC6_1C.cpp文件,完成程序的编写。

【输入】
输入文件SC6_1C.in有1行,包含3个实数,各实数之间用空格隔开。
【输出】
输出文件SC6_1C.out有1行,包含从小到大排列的3个实数,各实数之间用空格隔开。
【输入输出样例1】
SC6_1C.in SC6_1C.out
35.3 21.73 28.92 21.73 28.92 35.30
【输入输出样例2】
SC6_1C.in SC6_1C.out
65.12 45.39 34.78 34.78 45.39 65.12
【数据限制】
所有数据均可用double类型表示。

#include "stdio.h"
void swap( double *x, double *y){
   //按地址传递方式交换2个实数(实际交换)
	double t;
	//******************************************
	t = *x;
	*x = *y;
	*y = t;
	
	//==========================================
}
void sort3(double *a, double *b, double *c ){
   //实现三个实数的从小到大排序
	if(*a > *b) swap(a, b);
	//******************************************
	if(*b > *c) swap(b, c);
	
	if(*a 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值