因为循环部分的基础代码已经写完了,小博最近这两天整理复习数组方面的代码,所以停更了几天
接下来就是数组部分代码,emmmmmm…… 有点难度 加油
例题1 计算,保存和输入yi的值 yi=2sin ^2xi+ 5sinxi^2;i=1,2,…,10,xi由键盘输入
思想:定义X[10]存储由键盘输入的10个数,定义Y[10]存储最后的结果,首先键盘输入10个数存到数组x[10]中,然后for循环依次计算这十个数对应的y的值,存储到y[]中,最后打印y[]。
代码如下:
#include <stdio.h>
#include "math.h"
void main()
{
int i;
float x[10];//键盘输入xi
double y[10];//保存yi
for(i=0;i<10;i++)//输入xi
{
printf("请输入x[%d]的值:",i+1);
scanf("%f",&x[i]);
}
for(i=0;i<10;i++)//计算yi
{
y[i]=2*sin(x[i])*sin(x[i])+5*sin(x[i]*x[i]);
}
printf("结果为:\n");//打印
for (i=0;i<10;i++)
{
printf("y[%d]=%f\n",i+1,y[i]);
}
}
看一下结果:
例题2 将一组数据存入到一维数组中,并且排序。从键盘输入一个数,要求按照原来的顺序将它插入到适当的位置
思想:建议看看《数据结构》线性表插入删除部分
代码如下:
#include "stdio.h"
#define NUM 20
void main()
{
int a[NUM],length=0;
int i,j,t,done;
printf("请输入要要排序的一组数(以-1结束):\n");
while (1);
{
scanf("%d",&a[length]);
length++;
if (a[length-1]==-1||length<NUM)
{
break ;
}
}
i=0;
do
{
done =1;
for(j=length-1;j>=i+1;j--)
if(a[j]<a[j-1])
{
done =0;
t=a[j];
a[j]=a[j-1];
a[j-1]=t;
}
i++;
}while((i!=length+1)&& ! done);
printf("排序后的数据为:\n");
for(i=1;i<length;i++)
printf("%2d",a[i]);
printf("\n请输入要删除的数据:");
scanf("%d",&t);
for(i=0;i<length;i++)
{
if(a[i]==t)
break;
}
if(i==length)
{
printf("该数组中没有这个数据!\n");
}
else
{
for(j=i;j<length;j++)
a[j]=a[j+1];
length--;
}
printf("删除后的数组为:\n");
for(i=1;i<length;i++)
printf("%d",a[i]);
printf("\n");
}