第一次作业
题目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;
}
void splitfloat( float x, int *intpart, float *fracpart )
{
*intpart=x;
*fracpart=x-*intpart;}
3.本题试调过程碰到问题及解决办法
无
git地址:https://git.coding.net/chenxu1999/diyicizuoye.git
题目6-2拆分实数的整数与小数部分
1.设计思路
(1)定义中间变量temp(小数部分)
(2)执行while循环每次减1直到把整数部分减没,剩下小数部分temp
(3)将整数部分和小数部分的值赋给相应的指针变量
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.本题调试过程碰到问题及解决办法
无
git地址:https://git.coding.net/chenxu1999/diyicizuoye.git
题目6-3在数组中查找指定元素
1.设计思路
(1)题目要求查找指定元素,如果找到返回元素最小的下标,否则返回-1。
(2)利用for循环逐个比较,用if语句进行判断。
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.本题调试过程碰到问题及解决方法
无
git地址:https://git.coding.net/chenxu1999/diyicizuoye.git
7-1 数组元素循环右移问题
1.设计思路
(1)第一步:阅读审题,理清思路
第二步:上机实验,补全函数
(2)流程图
略
2.实验代码
#include<stdio.h>
int main()
{
int i,n,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:无