第一次作业

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

题目6-2拆分实数的整数与小数部分

1.设计思路

(1)定义中间变量temp(小数部分)

(2)执行while循环每次减1直到把整数部分减没,剩下小数部分temp

(3)将整数部分和小数部分的值赋给相应的指针变量

2.实验代码

#include<stdio.h>
void solitfloat(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)
{
     float temp;
     temp=x;
     while(temp-1>=0)
     {
          temp--;
      }
     *intpart=x-temp;
     *fracpart=temp;
}

3.本题调试过程碰到问题及解决办法
(1)代码为while(temp-1>0)时,有部分正确

(2)代码为while(temp-1>=0)时,答案正确

(3)如果不>=0就会少一次temp--,运行结果就会都为1

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

1.设计思路

(1)题目要求查找指定元素,如果找到返回元素最小的下标,否则返回-1。

(2)利用for循环逐个比较,用if语句进行判断。

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

(1)不知道相等时执行返回值后还会不会执行不相等时的返回值,运行后发现只会有一个返回值。

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

1.设计思路

(1)主要描述题目算法

 ①题目要求实现将数组元素循环右移,且不允许使用另外数组。

 ②用scanf键盘输入数组元素个数,及右移的位数。

 ③第一次利用for循环给数组赋值。

 ④定义变量x当右移位数大于给定的数组元素时可以循环回来。

 ⑤第二次利用for循环输出被移后面的数。

 ⑥第三次利用for循环输出被移前面的数。

(2)流程图

 

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.本题调试过程碰到问题及解决方法
(1)当给定6个数组元素时不能右移7位

         解决办法:int x=m%n,利用余数实现循环回来。

 

posted @ 2018-04-07 18:17  王闹闹  阅读(229)  评论(0编辑  收藏  举报