的c语言算法 2,最常用的c语言算法

最常用的c语言算法

#define n 10

main()

{int a[n],i,j,k,t;

for(i=0;i

for(i=0;i

{k = i;

for(j=i+1;j

if(a[j] < a[k]) k = j;

if (k != i){t = a[i]; a[i] = a[k]; a[k] = t;}

}

for(i=0;i

printf("%d\n",a[i]); }

(3)插入法排序

要想很好地掌握此算法,先请了解“有序序列的插入算法”,就是将某数据插入到一个有序序列后,该序列仍然有序。插入算法参见下面的“数组元素的插入”。

例1、将任意读入的整数x插入一升序数列后,数列仍按升序排列。

#define n 10

main()

{ int a[n]={-1,3,6,9,13,22,27,32,49},x,j,k;

scanf("%d",&x);

if(x>a[n-2]) a[n-1]=x ;

else

{j=0;

while( j<=n-2 && x>a[j]) j++;

for(k=n-2; k>=j; k- -) a[k+1]=a[k];

a[j]=x; }

for(j=0;j<=n-1;j++) printf("%d ",a[j]);

}

插入法排序的要领就是每读入一个数立即插入到最终存放的数组中,每次插入都使得该数组有序。

例2、任意读入10个整数,将其用插入法按降序排列后输出。

#define n 10

main()

{int a[n],i,j,k,x;

scanf("%d",&a[0]);

for(j=1;j

{scanf("%d",&x);

if(x

else

{i=0;

while(x

for(k=j-1;k>=i;k--) a[k+1]=a[k];

a[i]=x;

}

}

for(i=0;i

}

(4)归并排序

即将两个都升序(或降序)排列的数据序列合并成一个仍按原序排列的序列。

例1、有一个含有6个数据的升序序列和一个含有4个数据的升序序列,将二者合并成一个含有10个数据的升序序列。

#define m 6

#define n 4

main()

{int a[m]={-3,6,19,26,68,100} ,b[n]={8,10,12,22};

int i,j,k,c[m+n];

i=j=k=0;

while(i

{if(a[i]

else {c[k]=b[j]; j++;}

k++; }

while(i>=m && j

{c[k]=b[j]; k++; j++;}

while(j>=n && i

{c[k]=a[i]; k++; i++;}

for(i=0;i

scanf("%d",&x);

for(i=0;i

if(i

else printf("Not found!\n");}

(2)折半查找(即二分法)

顺序查找的效率较低,当数据很多时,用二分法查找可以提高效率。使用二分法查找的前提是数列必须有序。

二分法查找的思路是:要查找的关键值同数组的中间一个元素比较,若相同则查找成功,结束;否则判别关键值落在数组的哪半部分,就在这半部分中按上述方法继续比较,直到找到或数组中没有这样的元素值为止。

例1、任意读入一个整数x,在升序数组a中查找是否有与x等值的元素。

#define n 10

main()

{int a[n]={2,4,7,9,12,25,36,50,77,90};

int x,high,low,mid;

scanf("%d",&x);

high=n-1; low=0; mid=(high+low)/2;

while(a[mid]!=x&&low

{if(x

else low=mid+1;

mid=(high+low)/2; }

if(x==a[mid]) printf("Found %d,%d\n",x,mid);

else printf("Not found\n");

}

三、数值计算常用经典算法:

1.级数计算

级数计算的关键是“描述出通项”,而通项的描述法有两种:一为直接法、二为间接法又称递推法。

直接法的要领是:利用项次直接写出通项式;递推法的要领是:利用前一个(或多个)通项写出后一个通项。

可以用直接法描述通项的级数计算例子有:

(1)1+2+3+4+5+……

(2)1+1/2+1/3+1/4+1/5+……等等。

可以用间接法描述通项的级数计算例子有:

(1)1+1/2+2/3+3/5+5/8+8/13+……

(2)1+1/2!+1/3!+1/4! +1/5!+……等等。

(1)直接法求通项

例1、求1+1/2+1/3+1/4+1/5+……+1/100的和。

main()

{float s; int i;

s=0.0;

for(i=1;i<=100;i++) s=s+1.0/i ;

printf("1+1/2+1/3+...+1/100=%f\n",s);

}

【解析】程序中加粗部分就是利用项次i的倒数直接描述出每一项,并进行累加。注意:因为i是整数,故分子必须写成1.0的形式!

(2)间接法求通项(即递推法)

例2、计算下列式子前20项的和:1+1/2+2/3+3/5+5/8+8/13+……。

[分析]此题后项的分子是前项的分母,后项的分母是前项分子分母之和。

main()

{float s,fz,fm,t,fz1; int i;

s=1;

fz=1;fm=2;

t=fz/fm;

for(i=2;i<=20;i++)

{s=s+t;

fz1=fz;

fz=fm;

fm=fz1+fm;

t=fz/fm;}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值