孟龄钊

第一次作业.

---恢复内容开始---

题目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=(int)x;
*fracpart=x-*intpart;

}

 

3.本体调试过程碰到问题及解决办法

未遇到问题

1.设计思路

(1)

第一步:阅读题目要求,变量名称和程序所给部分

第二步:将缺失函数补全

(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.本体调试过程碰到问题及解决办法

for循环与if使用混乱 将变量写成a

解决办法:重新整理思路 更改变量。

6-1计算两数的和与差

1设计思路

(1)

第一步:阅读题目要求及所给部分。

第二步:根据题意进行相应的加减,补全相应函数。

(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.本体调试过程碰到问题及解决办法

无。

7-1 数组元素循环右移问题

1设计思路

(1)

第一步:阅读题目要求。

第二步:建立函数,利用主函数对其进行调用

(2)流程图 略。

2.实验代码

#include <stdio.h>
#include <stdlib.h>

void move(int a[], int size)
{
    int i, t;
    t = a[size-1];
    for(i = size - 2; i >= 0; i--)
    {
        a[i+1] = a[i]; 
    }
    a[0] = t;
}
void out(int a[], int size)
{
    int i;
    for(i = 0; i < size; i++)
    {
        printf(i == size-1 ? "%d" : "%d ", a[i]);
    }
}
int main(void)
{
    int array[100];
    int i, N, M;
    scanf("%d %d", &N, &M);
    for(i = 0; i < N; i++)
        scanf("%d", &array[i]);
    for(i = 0; i < M; i++)
    {
        move(array, N);
    }
    ot(array, N);

    return 0;}

3.本体调试过程碰到问题及解决办法

move函数中 移动关系整理不清。

解决方法:重新设计。

posted on 2018-04-06 22:19  孟龄钊  阅读(91)  评论(1编辑  收藏  举报

导航