2019春第六周作业
这个作业属于那个课程 | C语言程序设计II |
---|---|
这个作业要求在哪里 | https://edu.cnblogs.com/campus/zswxy/computer-scienceclass1-2018/homework/2892 |
我在这个课程的目标是 | 掌握好指针这方面 |
这个作业在那个具体方面帮助我实现目标 | 能让我去思考指针为什么可以这么写 |
参考文献 | C语言程序设计II |
基础作业
6-1 求两数平方根之和 (10 分)
函数fun的功能是:求两数平方根之和,作为函数值返回。例如:输入12和20,输出结果是:y = 7.936238。
函数接口定义:
double fun (double *a, double *b);
其中 a和 b是用户传入的参数。函数求 a指针和b 指针所指的两个数的平方根之和,并返回和。
裁判测试程序样例:
include<stdio.h>
include <math.h>
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
实验代码
#include<stdio.h>
#include <math.h>
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;
}
double fun (double *a, double *b)
{
double t;
t=sqrt(*b)+sqrt(*a);
return t;
}
设计思路
本题调试过程碰到问题及解决办法:
很简单,没问题
运行结果:
7-1 利用指针返回多个函数值 (30 分)
读入n个整数,调用max_min()函数求这n个数中的最大值和最小值。
输入格式:
输入有两行: 第一行是n值; 第二行是n个数。
输出格式:
输出最大值和最小值。
输入样例:
在这里给出一组输入。例如:
5
8 9 12 0 3
输出样例:
在这里给出相应的输出。例如:
max = 12
min = 0
实验代码:
#include<stdio.h>
void max_min(int a[],int len,int* px,int* pn);
int main()
{
int n,i,max,min,len=0;
scanf("%d",&n);
int a[n];
for(i=0;i<n;i++){
scanf("%d",&a[i]);
len++;
}
max_min(a,len,&max,&min);
printf("max = %d\nmin = %d",max,min);
return 0;
}
void max_min(int a[],int len,int* px,int* pn)
{
int i;
*px=a[0];
*pn=a[0];
for(i=1;i<len;i++){
if(*px<a[i]) *px=a[i];
if(*pn>a[i]) *pn=a[i];
}
}
设计思路
本题调试过程碰到问题及解决办法:
之前做过比较大小的题,只要改一下指针变量就行,所以没什么大问题。
运行结果:
思考题:
1.为什么要使用指针?它有什么用?
指针有利于大块数据的管理,但也更危险。特别是已经存在于内存中的数据,通过指针访问更方便。
指针就是指向一个特定内存地址的一个变量。C语言指针可以有效地表示复杂的数据结构、动态分配内存、高效地使用数组和字符串、使得调用函数时得到多个返回值等。指针的应用往往与数组联系在一起,是最频繁的,也是最基础的。
2.指针变量在内存中暂用多大的空间?它的大小由什么决定?
有人说是这样的
32位处理器上32位操作系统的32位编译器,指针大小4字节。
32位处理器上32位操作系统的16位编译器,指针大小2字节。
32位处理器上16位操作系统的16位编译器,指针大小2字节。
16位处理器上16位操作系统的16位编译器,指针大小2字节。
指针大小是由当前CPU运行模式的寻址位数决定!
也有这样的:
在C中, 指针只有3种:
指向简单变量的, 指向结构体变量的, 指向函数的.
他们的大小和指向的类型无关, 基本都是一样的, 等于地址宽度.
在16位的地址的系统里, 用 段:偏移 来表示一个地址,
当只用偏移的时候(段内)称为NEAR指针, 当段偏移都用的时候(跨段), 称为FAR指针,
FAR指针占用空间大于NEAR指针.
但是在32位系统中, 指针大小是统一的.
指针变量所占空间大小和该指针变量指向的数据类型没有任何直接关系,同一编译器下,同一编译选项下所有类型的指针变量大小都是一样的,指针变量的大小是编译器所对应的系统环境所决定的,或者说是由编译器决定的
所以到底是什么?
挑战作业
跳过,不会
预习作业
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<stdio.h>
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
实验代码
#include<stdio.h>
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;
}
void input(int *arr,int n)
{
int i;
for (i=0;i<10;i++)
{
scanf("%d",&arr[i]);
}
}
void max_min(int *arr,int n)
{
int i=0,min=arr[0],max=0,MIN=0,MAX=0;
int temp;
for(i=0;i<10;i++)
if(arr[i]<min)
{
min=arr[i];
MIN=i;
}
for(i=0;i<10;i++)
if(arr[i]>max)
{ max=arr[i];
MAX=i;
}
temp=arr[0];
arr[0]=arr[MIN];
arr[MIN]=temp;
temp=arr[9];
arr[9]=arr[MAX];
arr[MAX]=temp;
}
void output(int *arr,int n)
{
int i;
for(i=0;i<n;i++)
{
printf("%3d",arr[i]);
}
}
设计思路
本题调试过程碰到问题及解决办法:
运行结果:
学习进度统计和学习感悟
周/日期 | 这周所用时间 | 代码行 | 学到的知识点简介 | 目前比较迷惑的问题 |
---|---|---|---|---|
3/30-4/5 | 8小时 | 110行左右 | 指针变量 | 指针还是不太会 |
描述结对编程过程和结对编程的优缺点
我觉得结对编程很好,可以有不同的思路和见解。
缺点就是两个人都不会,做题效率有点低