第一次作业

第一次PTA作业
6-1拆分实数的整数与小数部分
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=x;
 *fracpart=x-*intpart;}

3.本体调试过程碰到问题及解决办法
错误信息1:无
错误原因1:无
git地址:https://git.coding.net/bai981005/diycizuoye.git

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){
 
    int i;
    for(i = 0; i <= n; i++)
        if(list[i] == x)
            return i;
     
    return -1;
}

3.本体调试过程碰到问题及解决办法
错误信息1:无
错误原因1:无
git地址:https://git.coding.net/bai981005/diycizuoye.git

6-1计算两数的和与差
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:无
错误原因1:无
git地址:https://git.coding.net/bai981005/diycizuoye.git

7-1 数组元素循环右移问题
1设计思路
(1)
第一步:阅读题目要求。
第二步:建立函数,利用主函数对其进行调用
(2)流程图
无。
(3)实验代码

#include<stdio.h>
int main()
{
    int a[100];
    int i,N,M,t;
    scanf("%d %d",&N,&M);
    for(i=0;i<N;i++)
    scanf("%d",&a[i]);
       
    for(int 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++)
  printf(i==N-1?"%d":"%d ",a[i]);
    return 0;
}

3.本体调试过程碰到问题及解决办法
错误信息1:无
错误原因1:无
git地址:https://git.coding.net/bai981005/diycizuoye.git

posted on 2018-04-07 16:14  王浩百  阅读(157)  评论(0编辑  收藏  举报

导航