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;
}
splitfloat(float a,int *c,float *b)
{
*c = a;
*b = a - *c ;
}
3.本体调试过程碰到问题及解决办法
错误信息1:无
错误原因1:无
git地址:https://git.coding.net/gbztdn/diyicizuoye.git
6-2在数组中查找指定元素
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 a[], int n , int x)
{
int i;
for(i=0;i<n;i++)
{
if(a[i]==x)
return i;
}
return -1;
}
3.本体调试过程碰到问题及解决办法
错误信息1:无
错误原因1:无
git地址:https://git.coding.net/gbztdn/diyicizuoye.git
6-3计算两数的和与差
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;
}
sum_diff(float a,float b,float *p1,float *p2)
{
*p1=a+b;
*p2=a-b;
}
3.本体调试过程碰到问题及解决办法
错误信息1:无
错误原因1:无
git地址:https://git.coding.net/gbztdn/diyicizuoye.git
7-1 数组元素循环右移问题
1设计思路
(1)第一步:阅读题目要求。
第二步:建立函数,利用主函数对其进行调用
2.实验代码
/*
将一个有n个元素的数组,循环向右移动
6 2
1 2 3 4 5 6
5 6 1 2 3 4
最后一行不能有空格
*/
//遍历数组 然后将n行的数放在第一位 其他依此向后排列
#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:无
错误原因1:无