第一次作业.
---恢复内容开始---
题目6-1拆分实数整数及小数部分
1设计思路
(1)
第一步:阅读题目要求及所给部分。
第二步:根据题意补全相应函数。
(2)流程图
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=(int)x; *fracpart=x-*intpart; }
3.本体调试过程碰到问题及解决办法
未遇到问题
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; for(i=0;i<n;i++) if(list[i]==x) return (i); return -1; }
3.本体调试过程碰到问题及解决办法
for循环与if使用混乱 将变量写成a
解决办法:重新整理思路 更改变量。
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.本体调试过程碰到问题及解决办法
无。
7-1 数组元素循环右移问题
1设计思路
(1)
第一步:阅读题目要求。
第二步:建立函数,利用主函数对其进行调用
(2)流程图 略。
2.实验代码
#include <stdio.h> #include <stdlib.h> void move(int a[], int size) { int i, t; t = a[size-1]; for(i = size - 2; i >= 0; i--) { a[i+1] = a[i]; } a[0] = t; } void out(int a[], int size) { int i; for(i = 0; i < size; i++) { printf(i == size-1 ? "%d" : "%d ", a[i]); } } int main(void) { int array[100]; int i, N, M; scanf("%d %d", &N, &M); for(i = 0; i < N; i++) scanf("%d", &array[i]); for(i = 0; i < M; i++) { move(array, N); } ot(array, N); return 0;}
3.本体调试过程碰到问题及解决办法
move函数中 移动关系整理不清。
解决方法:重新设计。