题目6-1拆分实数的整数与小数部分
1.设计思路;
(1)第一步:定义两个与X有关的变量,一个用整型变量,一个用小数变量,让有机会进行下一步。
第二步:X1,X2,分别整除1,得到的为整数部分,剩下的再用X减去整数得到小数部分。
第三步:最后,由题意,进行赋值。看程序正确与否。
(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;
}
#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;
}
3.本题调试过程碰到问题及解决方法;
错误信息1:由于马虎,忽略了后面大括号;
错误原因:各种符号在C中都要加以注意。
git地址:
题目6-2 在数组中查找指定元素
第一步:了解各个参数的意义,从而定义各种变量的意义。
第二步:让函数实现各部分的功能。
第三步:测试程序的运行。
(2)流程图
无。
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,a;
a=n;
for(i=0;i<n;i++)
{while(x==list[i])
return i;
a--;
}
if(a==0)
return -1;
}
3.本题调试过程碰到的问题及解决办法
错误信息:等于和双等于的错误。
错误原因:在编写程序时,没有 分清等号和双等号的意义;
改正方法:多次运行后,看下面的错误信息,进行更改。
git地址:
题目6-3:计算两数的和与差
1.设计思路:
(1)第一步:了解在题中的意义
第二步:编写各个变量,让其在各个实现相应的规定及目的
第三步:运行各个程序,观察在其中的错误。
(2)流程图
无。
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地址:
题目7-1:数组元素循环右移问题
1.设计思路:
(1)第一步:了解题中各个元素的意义,
第二步:编写函数,达到想要实现的目的,
第三步:检验程序的运行正确与否
(2)流程图
无。
2.实验代码
#include<stdio.h>
#define N 100
int main()
{
int a[N];
int i,j,k,n,m,temp=0;
scanf("%d %d",&n,&m);
for(i=0;i<n;i++)
scanf("%d",&a[i]);
for(j=0;j<m;j++)
{
temp=a[n-1];
for(k=n-1;k>=0;k--)
{
a[k]=a[k-1];
if(k==0)
{
a[k]=temp;
}
}
}
for(i=0;i<n;i++)
{
if(i==n-1)
printf("%d",a[i]);
else
printf("%d ",a[i]);
}
return 0;
}
3.本题调试过程遇到问题及解决方法
错误信息1:最后一个元素不变
错误原因:没有保存最后一个数组。
改正方法:看下面的错误原因,加以改正。
git地址: