第一次作业

题目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;
}
splitfloat(float a,int *c,float *b)
 {*c = a;
  *b = a - *c ;}

3.本题调试过程碰到问题及解决办法
错误信息1:无

错误原因:无
改正方法:无
git地址:https://git.coding.net/zyx1999/111.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;
}
#include<stdio.h>

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

}

3.本题调试过程碰到问题及解决办法
错误信息1:定义主函数 用了void
错误原因:定义主函数 用了void
改正方法:void改成int
git地址:https://git.coding.net/zyx1999/111.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; 
}

#include<stdio.h>
 sum_diff(float a,float b,float *c1,float *c2)
{
  *c1=a+b;
  *c2=a-b;
  
}

3.本题调试过程碰到问题及解决办法
错误信息1:编写函数时加了分号
错误原因:无
改正方法:去掉分号
git地址:https://git.coding.net/zyx1999/111.git

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

2.实验代码

/*
将一个有n个元素的数组,循环向右移动
6 2
1 2 3 4 5 6
5 6 1 2 3 4
最后一行不能有空格
*/
//遍历数组 然后将n行的数放在第一位 其他依此向后排列
#include<stdio.h>
int main()
{
    int n,i,m;
    scanf("%d %d",&n,&m);
    int a[n];
    for(i = 0;i < n;i++)
    {
        scanf("%d",&a[i]);
    }
    int x = m % n ;
    //
    for(i = n - x;i < n;i++)
        printf("%d ",a[i]);
    for(i = 0; i<n-x-1;i++)
        printf("%d ",a[i]);
    printf("%d",a[n-x-1]);
    return 0;
}

3.本题调试过程碰到问题及解决办法
错误信息1:最后一个数组元素不循环右移
错误原因:忘记保存数组最后一个元素
改正方法:保存数组最后一个元素
git地址:https://git.coding.net/zyx1999/111.git

posted @ 2018-04-07 10:28  张雨欣啊  阅读(89)  评论(0编辑  收藏  举报