第一次作业

Posted 于海波

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第一次作业相关的知识,希望对你有一定的参考价值。

题目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 )
{
	int a;
	float b;
	a=x/1;
	b=x-a;
	*intpart=a;
	*fracpart=b; 
} 

3.本题调试过程碰到问题及解决办法
错误信息1:无
错误原因:无
改正方法:无
git地址:https://git.coding.net/yhb2662857311/PTA.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,a;
    a=n;
    for(i=0;i<n;i++)
      {while(x==list[i])
      return i;
      a--;
      }
    if(a==0)
    return -1;  
      
}

3.本题调试过程碰到问题及解决办法
错误信息1:定义主函数 用了void
错误原因:定义主函数 用了void
改正方法:void改成int
git地址:https://git.coding.net/yhb2662857311/PTA.git

题目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://git.coding.net/yhb2662857311/PTA.git

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

2.实验代码

#include<stdio.h>
#define N 100
int main()
{
    int a[N];
    int i,j,k,n,m,temp=0;
    scanf("%d %d",&n,&m);    
    for(i=0;i<n;i++)
    scanf("%d",&a[i]);
    for(j=0;j<m;j++) //移动次数 
    {
        temp=a[n-1];   //保存最后一位数 
        for(k=n-1;k>=0;k--)     
        {       
            a[k]=a[k-1];    //向后移动 
            if(k==0)
            {
                a[k]=temp;
            }
        }
    }
    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://git.coding.net/yhb2662857311/PTA.git

总结:在一些细节上出错,太过粗心!

以上是关于第一次作业的主要内容,如果未能解决你的问题,请参考以下文章

HTML5期末大作业:餐饮美食网站设计——咖啡(10页) HTML+CSS+JavaScript 学生DW网页设计作业成品 web课程设计网页规划与设计 咖啡网页设计 美食餐饮网页设计...(代码片段

201621044079 韩烨作业09-集合与泛型

20155234 2017-2018-1《信息安全系统设计基础》课程总结

201621123062《java程序设计》第九周作业总结

第九次作业

作业第三周作业