第一次作业

题目6-1 拆分实数的整数与小数部分
1.设计思路
(1)第一步:观察题意了解各个参数与所需函数在题目中的意义;
第二步:设计算法编写函数,让函数的功能实现题目中所需的功能;
第三步:运行程序检测是否错误。
(2)流程图

2.实验代码

本题要求实现一个拆分实数的整数与小数部分的简单函数。
函数接口定义:

void splitfloat( float x, int *intpart, float *fracpart );

其中x是被拆分的实数(0≤x<10000),*intpart和*fracpart分别是将实数x拆分出来的整数部分与小数部分。
裁判测试程序样例:

#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:float类型不能取余
错误原因:float类型不能取余
改正方法:定义一个整型和单精度型的变量,令整型等于整数部分,单精度型等于小数部分
git地址:https://git.coding.net/ZXL1104/11111.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 ){
  for(int i=0;i<n;i++)
    if(x==list[i])
      return i;
    return -1;  
}

3.本题调试过程碰到问题及解决办法
错误信息1:无
错误原因:无
改正方法:无
git地址:https://git.coding.net/ZXL1104/11111.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/ZXL1104/11111.git
题目7-1 数组元素循环右移问题
1.设计思路
(1)第一步:先阅读题目找准要点,在脑海里构建代码思路。
第二步:读好题后然后在编程软件上写出代码,看是否正确。
第三步: 思考是否有最优方案。
(2)流程图

2.实验代码

#include<stdio.h>
#include<stdlib.h> 
#define w 100
main()
{
    int a[w];
    int i,j,k,n,m,t=0;
    scanf("%d %d",&n,&m);    
    for(i=0;i<n;i++)
    scanf("%d",&a[i]);
    for(j=0;j<m;j++) 
    {
        t=a[n-1]; 
        for(k=n-1;k>=0;k--)     
        {       
            a[k]=a[k-1]; 
            if(k==0)
            {
                a[k]=t;
            }
        }
    }
    for(i=0;i<n;i++)
    {

        if(i==n-1)
            printf("%d",a[i]);

        else
            printf("%d ",a[i]);
    }
   system("pause");
} 

3.本题调试过程碰到问题及解决办法
错误信息1:无
错误原因:无
改正方法:无
git地址:https://git.coding.net/ZXL1104/11111.git

学习总结:指针前一部分还可以跟的上,能够理解。但是到后边的字符什么的,就听不太懂了。

posted @ 2018-03-29 22:07  影孓ぃ  阅读(224)  评论(1编辑  收藏  举报