代码改变世界

第一次作业

2018-04-07 11:48  安徒生啊  阅读(122)  评论(0编辑  收藏  举报

6.1拆分实数整数及小数部分
1.设计思路:
(1)
第一步:阅读题目要求及所给部分。
第二步:根据题意补全相应函数。
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.调试过程中碰到的问题和解决办法:
没有问题
git地址:https://git.coding.net/antus/diyicizuoye.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 a[], int n , int b)
{
    int i;
    for(i=0;i<n;i++)
    {
        if(a[i]==b)
            return i;
    }
    return -1;

}

3.调试过程中遇到的问题和解决办法:

没有问题

git地址:https://git.coding.net/antus/diyicizuoye.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; 
}
sum_diff(float a,float b,float *p1,float *p2)
{
    *p1=a+b;
    *p2=a-b;
}


3.调试过程中遇到的问题和解决办法:
没有问题
git地址:https://git.coding.net/antus/diyicizuoye.git

7.1数组元素循环右移问题
1.设计思路:
(1)
第一步:审题
第二步:设计函数,利用主函数对其调用
(2)流程图:无

#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.调试过程中遇到的问题和解决办法:
没有问题
git地址:https://git.coding.net/antus/diyicizuoye.git