pta第一次作业

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;
}

 

void splitfloat( float x, int *intpart, float *fracpart )
{
int y;
y=x;
*intpart=y;
*fracpart=x-y;
}

```

https://git.coding.net/xaioliang/123.git

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

 

题目6-2 在数组中查找指定元素

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

```

https://git.coding.net/xaioliang/123.git

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

 

题目6-3 计算两数的和与差
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;
}

```

https://git.coding.net/xaioliang/123.git

 

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

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

2.实验代码
```

#include<stdio.h>
int main()
{
void move(int [20],int,int);
int number[20],N,M,i;
scanf("%d %d",&N,&M);
for(i=0;i<N;i++)
scanf("%d",&number[i]);
move(number,N,M);
for(i=0;i<N;i++)
printf("%d ",number[i]);
printf("\n");
return 0;
}
void move(int array[20],int N,int M)
{
int *p,array_end;
array_end=*(array+N-1);
for(p=array+N-1;p>array;p--;
*p=*(p-1);
*array=array_end;
M--;
if(M>0) move(array,N,M);
}

```

https://coding.net/u/xaioliang/p/123/git/new/master/?public=true

 

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

 

posted @ 2018-04-07 11:42  梁贺明  阅读(159)  评论(0编辑  收藏  举报