第一次作业
题目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,利用余数实现循环回来。