首页 > 其他 > 详细

第二学期-第一次作业

时间:2018-03-25 13:55:48      阅读:287      评论:0      收藏:0      [点我收藏+]

C高级第一次PTA作业(1)

技术分享图片

 

1. 计算两数的和与差

1.设计思路

第一步:设出被调用函数 op1, op2, *psum,  *pdiff ,利用被调函数计算*psum的值和*pdiff的值;

第二步:代入到主函数就是计算a、b的和与差;

第三部:对所得到数值进行输出;

2.流程图

技术分享图片技术分享图片

3.插入代码

1 void sum_diff( float op1, float op2, float *psum, float *pdiff )
2 {
3   *psum = op1 + op2;
4   *pdiff = op1 - op2;
5 }

4.本题调试中遇到的问题:

未遇到问题;

2. 拆分实数的整数与小数部分

1.设计思路

第一步:根据主函数,设出被调用函数x, *intpart, *fracpart ,计算出*intpart的值、*fracpart的值;

第二步:主函数中输入函数x、fracpart,并且输入x的值,利用被调函数得出intpart和fracpart的值;

第三步:对所得到数值进行输出;

2.流程图

技术分享图片技术分享图片

 

3.插入代码

1 void splitfloat( float x, int *intpart, float *fracpart )
2 {
3   *intpart = (int)x;
4   *fracpart = x - *intpart;
5 }

C高级第一次PTA作业(2)

技术分享图片

1 .在数组中查找指定元素

 1.设计思路

第一步:利用主调函数设出被调函数list[],  n, x,定义i、index、n、x为整形,输入n;

第二步:利用for循环输入a[i],调用被调函数确定index的值;

第三步:被调函数中,设j、q,为整形,利用for循环,寻找是否有x = list[j],如果有,则使q = j,如果没有,则q= -1;

第四步:利用if条件句,输出结果;

2.流程图

 技术分享图片技术分享图片

3.插入代码

 1     int search( int list[], int n, int x )
 2     {
 3         int j,q=-1;
 4         for(j=0;j<n;j++)
 5         {
 6             if(x==list[j])
 7             {
 8             q=j;
 9             break;    
10             }
11         }
12         return(q);
13     }

2 .找最大值及其下标

1.设计思路

第一步:N =10,根据主调函数写出被调函数*a、*b、n,设q和j、q=a[0];

第二步:利用for循环查出是否有q < a[j],如果有,则把a[i]的值赋给q,j的地址赋给b;

第三步:另a[N]、i、max、p为整形,设p = 0;利用for循环输入a[i]的值,根据被调用函数比较出a、&p、N的最大值;

第四步:输出所得的最大值和p的值。

2.流程图

技术分享图片技术分享图片

3.插入代码

 1 int fun(int *a,int *b,int n)
 2 {
 3         int q = a[0];
 4         int j;
 5         for(j=0;j<n;j++)
 6         {
 7             if(q < a[j])
 8             {
 9                 q = a[j];
10                 *b = j;
11             }
12         }
13         return(q);
14     }

C高级第一次PTA作业(3)

 技术分享图片

1 .最小数放前最大数放后

1.设计思路

最重要的是被调函数的填写

第一步: 设出三个被调用函数,input(int*arr,int n)函数输入n个元素到arr中。

               另i为整形,利用for循环在a[i]中输入10个新的元素。

 第二步:max_min(int *arr, int n)函数求指针arr所指向的一维数组中的最大值和最小值,其中最小的数与第一个数对换,将最大的数与最后一个数对换。

               设最小的元素和最大的元素都为a[0],令 i,temp,int ,q,w为整形,其中q= 0,w = 0;利用for循环把最大值和最小值进行赋值,q, w分别为最小值和最大                 值的下标。把所查找出的最大的下标与为加入数据前最大的数进行交换,把a[w]与a[rr+n-1]交换,同理,把a[p]与a[arr+0]作交换。

第三步:output(int*arr,int n)在一行中输出数组元素,每个元素输出占3列。使i为整形,利用for循环输出a[arr+i]的值。

2.流程图

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

              

  

 

 

 

 

 

 

 

 

 

 

 

第二学期-第一次作业

原文:https://www.cnblogs.com/sun031915/p/8644175.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!