6-1 拆分实数的整数与小数部分(15 分)
1.设计思路
(1)第一步:了解指针在此处的用处;
第二步:根据题意编写函数;
第三步:利用强制转换取的整数部分,在通过相减得到小数部分。
(2)流程图

2.实验代码

#include <stdio.h>
void splitfloat( float x, int *intpart, float *fracpart );
int main()
{
    float x, fracpart;
    int intpart;

    scanf("%f", &x);
    splitfloat(x, &intpart, &fracpart);
    printf("The integer part is %d\n", intpart);
    printf("The fractional part is %g\n", fracpart);

    return 0;
}
void splitfloat( float x, int *intpart, float *fracpart ){
  *intpart=(int)x;
  *fracpart=x-*intpart;
}

3.本题调试过程碰到问题及解决办法
错误信息1:无
错误原因:无
改正方法:无
git地址:https://coding.net/u/zhong123456/p/pta1/git?public=true
题目6-2 在数组中查找指定元素
1 设计思路
(1)主要描述题目算法
第一步:了解参数在题目中的意义;
第二步:设计算法编写函数;
第三步:运行程序判断错误。
(2)流程图
2.实验代码

#include <stdio.h>
#define MAXN 10
int search( int list[], int n, int x );
int main()
{
    int i, index, n, x;
    int a[MAXN];

    scanf("%d", &n);
    for( i = 0; i < n; i++ )
        scanf("%d", &a[i]);
    scanf("%d", &x);
    index = search( a, n, x );
    if( index != -1 )
        printf("index = %d\n", index);
    else
        printf("Not found\n");

    return 0;
}
int search( int list[], int n, int x )
{
  for(int i=0;i<n;i++)
    if(x==list[i])
      return i;
      return -1;
}

3.本题调试过程碰到问题及解决办法
错误信息1:无
错误原因:无
改正方法:无
git地址:https://coding.net/u/zhong123456/p/pta1/git/blob/master/2?public=true

题目6-3 计算两数的和与差
1.设计思路
(1)第一步:根据题意参数与函数在题目中的意义;
第二步:设计算法编写函数,让函数的功能实现题目中所需的功能;
第三步:运行程序检测错误。
(2)流程图

2.实验代码

#include <stdio.h>

void sum_diff( float op1, float op2, float *psum, float *pdiff );

int main()
{
    float a, b, sum, diff;

    scanf("%f %f", &a, &b);
    sum_diff(a, b, &sum, &diff);
    printf("The sum is %.2f\nThe diff is %.2f\n", sum, diff);
	
    return 0; 
}
void sum_diff( float op1, float op2, float *psum, float *pdiff ){
  *psum = op1+op2;
  *pdiff = op1-op2;
}

3.本题调试过程碰到问题及解决办法
错误信息1:无
错误原因:无
改正方法:无
git地址:https://coding.net/u/zhong123456/p/pta1/git/blob/master/3?public=true

题目7-1 数组元素循环右移问题
1.设计思路
(1)第一步:观察题意了解参数与函数在题目中的作用;
第二步:设计算法编写函数,让函数的功能实现题目中所需的功能;
第三步:运行程序检测错误。
(2)流程图

2.实验代码

#include<stdio.h>
int main()
{
    int t = 0,N,M,i,j;
    int a[100]= {0};
    scanf("%d %d",&N,&M);
    for(i=0;i<N;i++)
        scanf("%d",&a[i]);
    for(j=0;j<M;j++)
    {
        t=a[N-1];
        for(i=N-2;i>=0;i--)
        {
            a[i+1]=a[i];
        }
        a[0]=t;
    }
    for(i=0;i<N;i++)
    {
        if(i<N-1)
        printf("%d ",a[i]);
        else
            printf("%d",a[i]);
    }
    return 0;
}

3.本题调试过程碰到问题及解决办法
错误信息1:出现段错误;
错误原因:开始时并未保存数组的最后一位数;
改正方法:保存最后一位数;
git地址:https://coding.net/u/zhong123456/p/pta1/git/blob/master/-4?public=true

posted on 2018-04-01 12:57  包钟鹏  阅读(195)  评论(4编辑  收藏  举报