上海龙凤419

C说话

最经常利用的c说话算法有哪些

时候:2024-06-02 20:20:40 C说话 我要投稿
  • 相干保举

最经常利用的c说话算法有哪些

  大师晓得最经常利用的c说话算法有哪些吗?上面小编为大师清算了最经常利用的c说话算法,但愿能帮到大师!

  一、根基算法

  1.互换(两量互换借助圈外人)

  例1、肆意读入两个整数,将两者的值互换后输出。

  main()

  {int a,b,t;

  scanf("%d%d",&a,&b);

  printf("%d,%d ",a,b);

  t=a; a=b; b=t;

  printf("%d,%d ",a,b);}

  【剖析】法式中加粗局部为算法的焦点,犹如互换两个杯子里的饮料,必须借助第三个空杯子。

  假定输出的值别离为3、7,则第一行输出为3,7;第二行输出为7,3。

  此中t为中心变量,起到“空杯子”的感化。

  注重:三句赋值语句赋值号摆布的各量之间的干系!

  【利用】

  例2、肆意读入三个整数,而后按从小到大的挨次输出。

  main()

  {int a,b,c,t;

  scanf("%d%d%d",&a,&b,&c);

  if(a>b){ t=a; a=b; b=t; }

  if(a>c){ t=a; a=c; c=t; }

  if(b>c) { t=b; b=c; c=t; }

  printf("%d,%d,%d ",a,b,c);}

  2.累加

  累加算法的方式是形如“s=s+A”的累加式,此式必须呈现在轮回中能力被频频履行,从而完成累加功效。“A”凡是是有纪律变更的抒发式,s在进入轮回前必须取得适合的初值,凡是为0。

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

  main()

  {int i,s;

  s=0; i=1;

  while(i<=100)

  {s=s+i;

  i=i+1;

  }

  printf("1+2+3+...+100=%d ",s);}

  【剖析】法式中加粗局部为累加式的典范情势,赋值号摆布都呈现的变量称为累加器,此中“i = i + 1”为特别的累加式,每次累加的值为1,如许的累加器又称为计数器。

  3.累乘

  累乘算法的方式是形如“s=s*A”的累乘式,此式必须呈现在轮回中能力被频频履行,从而完成累乘功效。“A”凡是是有纪律变更的抒发式,s在进入轮回前必须取得适合的初值,凡是为1。

  例1、求10!

  [阐发]10!=1×2×3×……×10

  main()

  {int i; long c;

  c=1; i=1;

  while(i<=10)

  {c=c*i;

  i=i+1;

  }

  printf("1*2*3*...*10=%ld ",c);}

  二、非数值计较经常利用典范算法

  穷举

  也称为“列举法”,行将能够呈现的每种环境逐一测试,判定是不是知足前提,普通接纳轮回来完成。

  例1、用穷举法输出一切的水仙花数(即如许的三位正整数:其每位数位上的数字的立方和与该数相称,比方:13+53+33=153)。

  [法一]

  main()

  { int x,g,s,b;

  for(x=100;x<=999;x++)

  {g=x; s=x/10; b=x/100;

  if(b*b*b+(s-10*b)*(s-10*b)*(s-10*b)+(g-10*s)*(g-10*s)*(g-10*s)==g)

  printf("%d ",x);}

  }

  【剖析】此方式是将100到999一切的三位正整数逐一考查,行将每个三位正整数的个位数、十位数、百位数逐一求出(各数位上的数字的提取算法见上面的“数字处置”),算出三者的立方和,一旦与原数相称就输出。共斟酌了900个三位正整数。

  [法二]

  main()

  {int g,s,b;

  for(b=1;b<=9;b++)

  for(s=0;s<=9;s++)

  for(g=0;g<=9;g++)

  if(b*b*b+s*s*s+g*g*g==b*100+s*10+g) printf("%d ",b*100+s*10+g);

  }

  【剖析】此方式是用1到9做百位数字、0到9做十位和个位数字,将构成的三位正整数与每组的三个数的立方和停止比拟,一旦相称就输出。共斟酌了900个组合(外轮回零丁履行的次数为9,两个内轮回零丁履行的次数别离为10次,故if语句被履行的次数为9×10×10=900),即900个三位正整数。与法一判定的次数一样。

【最经常利用的c说话算法有哪些】相干文章:

C说话的经常利用新指令有哪些03-30

C说话的错误谬误有哪些12-04

C说话的特色及版本有哪些03-26

C说话assert的用法有哪些04-02

C说话中函数的辨别有哪些04-27

C说话中的主要观点有哪些12-11

PID算法的C说话完成12-04

计较机c说话的考点有哪些11-29

C说话挑选排序算法及实例代码11-25