博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第六周作业
阅读量:5278 次
发布时间:2019-06-14

本文共 2304 字,大约阅读时间需要 7 分钟。

本周作业头

这个作业属于哪个课程 C语言程序设计II
这个作业要求在哪里
我在这个课程的目标是 通过指针更快找到数据的位置,学会运用指针
这个作业在哪个具体方面帮助我实现目标 这个作业让我大概了解了指针的定义及用法
参考文献 c语言程序设计(第3版)

6-1 求两数平方根之和 (10 分)

函数fun的功能是:求两数平方根之和,作为函数值返回。例如:输入12和20,输出结果是:y = 7.936238。

函数接口定义:

double fun (double a, double b);

其中 a和 b是用户传入的参数。函数求 a指针和b 指针所指的两个数的平方根之和,并返回和。

裁判测试程序样例:

#include
#include
double fun (double *a, double *b); int main ( ){ double a, b, y;scanf ("%lf%lf", &a, &b ); y=fun(&a, &b); printf ("y=%.2f\n", y );return 0;}/* 请在这里填写答案 */

输入样例:

12 20

输出样例:

y=7.94

代码答案:

double fun(double *a, double *b){  double t;  t=sqrt(*a)+sqrt(*b);  return t;}

设计思路:

1580666-20190405191304829-2041639325.png

本题调试过程中碰到问题及解决方法

没有

运行结果截图

1580666-20190405191507191-1729701163.png

1580666-20190405191516830-426445106.png

7-1 利用指针返回多个函数值 (30 分)

读入n个整数,调用max_min()函数求这n个数中的最大值和最小值。

输入格式:

输入有两行: 第一行是n值; 第二行是n个数。

输出格式:

输出最大值和最小值。

输入样例:

在这里给出一组输入。例如:

58 9 12 0 3

输出样例:

在这里给出相应的输出。例如:

max = 12min = 0

实验代码:

#include
void max_min(int a[100],int n,int* pmax,int* pmin); int main(void){ int n,j,max,min; int *pmax,*pmin; int a[100]; scanf("%d",&n); for(j=0;j
a[j]) *pmin=a[j]; }}

设计思路

1580666-20190405192652991-297065226.png

运行结果截图

1580666-20190405192719757-1340361965.png

1580666-20190405192733600-145801188.png

6-3 最小数放前最大数放后 (10 分)

为一维数组输入10个整数;将其中最小的数与第一个数对换,将最大的数与最后一个数对换;输出数组元素。。

函数接口定义:

void input(int *arr,int n);void max_min(int *arr,int n);void output(int *arr,int n);

三个函数中的 arr和n 都是用户传入的参数。n 是元素个数。

input函数的功能是输入 n个元素存到指针arr所指向的一维数组中。

max_min函数的功能是求指针arr所指向的一维数组中的最大值和最小值,其中最小的数与第一个数对换,将最大的数与最后一个数对换。

output函数的功能是在一行中输出数组元素,每个元素输出占3列。

裁判测试程序样例:

#include
void input(int *arr,int n);void max_min(int *arr,int n);void output(int *arr,int n);int main(){ int a[10];input(a,10); max_min(a,10); output(a,10); return 0;}/* 请在这里填写答案 */

输入样例:

5 1 4 8 2 3 9 5 12 7

输出样例:

1  5  4  8  2  3  9  5  7 12

代码答案:

void input(int *arr,int n){    int i=0;    for(i=0;i
< n;i++) { if(*(arr+i)>max) { max=*(arr+i); indexmax=i; } } t=*(arr+n-1); *(arr+n-1)=max; *(arr+indexmax)=t; for(i=0;i

设计思路

1580666-20190405194011920-1254185349.png

运行结果截图

1580666-20190405194123726-299245834.png

1580666-20190405194134688-122426775.png

学习进度条

周/日期 这周所花的时间 代码行 学到的知识点简介 目前比较迷惑的问题
2/25-3/3 三天 45 数组的认识及用法 数组长度的理解
3/4-3/10 四天 38 文件的处理问题 文件指针的用法
3/11-3/16 三天 52 二维数组的使用及文件插入 二维数组的用法、上三角的判断及文件的处理
3/17-3/24 三天 102 用一维数组和二维数组编程 冒泡算法的运用
3/25-3/29 三天 66 学会规范的画流程图,认识了字符串 进制之间的转换的代码
4/1-4/5 三天 78 理解变量,内存和地址之间的关系

心得感悟

也没什么好说的,其实跟平时差不多,只是更累了点。

转载于:https://www.cnblogs.com/dingyuchen/p/10659586.html

你可能感兴趣的文章
linux杂谈(十九):DNSserver的配置(二)
查看>>
《网络攻防》第二周作业
查看>>
关于Windows Live Writer博客同步
查看>>
linux下的C语言快速学习—计算机体系结构基础简单了解
查看>>
nextTick refs
查看>>
内置函数
查看>>
ucore lab1实验笔记
查看>>
java内部类概念
查看>>
(60)zabbix网络发现介绍Network Discovery
查看>>
annotation本质
查看>>
shell之文本过滤(awk)
查看>>
学习进度条--第五周
查看>>
获取spring中所有的bean名称
查看>>
linux常用命令
查看>>
java DecimalFormat
查看>>
简单两步快速学会使用Mybatis-Generator自动生成entity实体、dao接口和简单mapper映射(用mysql和oracle举例)...
查看>>
Spring读书笔记-----Spring核心机制:依赖注入
查看>>
如何挂载阿里云的数据盘
查看>>
block extends include三者的差别跟用法
查看>>
服务器安全
查看>>