c语言算法描述
可行性,确定性,有穷性,拥有足够的情报(拥有一个或多个输出,有零个或多个输入)
‘贰’ c语言中什么是算法有哪些描述算法的例子
1、有穷性(有限性)。任何一种提出的解题方法都是在有限的操作步骤内可以完成的。
如果在有限的操作步骤内完不成,得不到结果,这样的算法将无限的执行下去,永远不会停止。除非手动停止。例如操作系统就不具有有穷性,它可以一直运行。
2、一个算法应该具有以下七个重要的特征:
1)有穷性(finiteness)
算法的有穷性是指算法必须能在执行有限个步骤之后终止
2)确切性(definiteness)
算法的每一步骤必须有确切的定义;
3)输入项(input)
一个算法有0个或多个输入,以刻画运算对象的初始情况,所谓0个输入是指算法本身定出了初始条件;
4)输出项(output)
一个算法有一个或多个输出,以反映对输入数据加工后的结果.没有输出的算法是毫无意义的;
5)可行性(effectiveness)
算法中执行的任何计算步都是可以被分解为基本的可执行的操作步,即每个计算步都可以在有限时间内完成;
6)
高效性(high
efficiency)
执行速度快,占用资源少;
7)
健壮性(robustness)
健壮性又称鲁棒性,是指软件对于规范要求以外的输入情况的处理能力。所谓健壮的系统是指对于规范要求以外的输入能够判断出这个输入不符合规范要求,并能有合理的处理方式。
‘叁’ C语言简单算法介绍
第一步:p=1,第二步:i=2,第三步:应该是p*i赋值给p,所以p*i=1*2 赋值给p
也就是现在的p=1*2,第四步:把i+1赋值给i,此时i=3,第五步:判断i是否大于五,没有返回到第三步:把p*i赋值给p,所以p*i=1*2*3 赋值给p
也就是现在的p=1*2*3,第四步:把i+1赋值给i,此时i=4,第五步:判断i是否大于五,没有返回到第三步:把p*i赋值给p,所以p*i=1*2*3*4 赋值给p
也就是现在的p=1*2*3*4,第四步:把i+1赋值给i,此时i=5,第五步:判断i是否大于五,没有返回到第三步:把p*i赋值给p,所以p*i=1*2*3*4*5 赋值给p
也就是现在的p=1*2*3*4*5,第四步:把i+1赋值给i,此时i=6,第五步:判断i是否大于五,有,结束。此时p=1*2*3*4*5=5!
这样i+1就是为了使得后面的乘3,乘4,乘5做准备的!
‘肆’ c语言算法的四种描述方法的特点
列表:普通的数组形式、链表形式队列:先进先出,删除在队首,添加在队尾栈:后进先出,添加和删除都在栈顶实现线性的数据结构的主要特点是首无前驱,尾无后继,中间的元素有唯一的前驱和后继
‘伍’ 请写下以下c语言的算法描述
#include "stdio.h"
int myfun(int (*p)[4])
{
int i,j,k;
for(i=0;i<4;p[i][3-i]=p[i][i++]=1); //将二条对角线的元素全部置为1
for(k=i=0;i<4;i++) //求所有元素的和
for(j=0;j<4;k+=p[i][j++]);
return k-8; //返回值为除8个对角线(值均为1)以外所有元素的和
}
void main(void){
int a[4][4],i,j,k,t=2; //t=2,结合下面的while循环,循环2次
while(t--)
{
printf("请输入16个数值作为4*4的数组\n");
for(i=0;i<4;i++) //输入4*4数组
for(j=0;j<4;scanf("%d",&a[i][j++]));
k=myfun(a); //调用函数
for(i=0;i<4;i++){ //输出调用后的数组
for(j=0;j<4;printf("%3d",a[i][j++]));
printf("\n");
}
printf("其余元素之和为:%d\n",k); //输出返回值,除二条对角线以外各元素的和
}
}
‘陆’ c语言问题: 什么是算法试从日常生活中找3个例子,描述它们的算法。 详细点,谢谢!
c语言中的算法是指:一系列解决问题的清晰指令,用系统的方法描述解决问题的策略机制。也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出。通俗说就是解决问题的方法和步骤。
描述算法的例子:
问题:从上海去到北京。
其中的算法:做汽车、做飞机、或者徒步。
问题:喝茶。
其中的算法:先找到茶叶,再烧一壶开水,然后将茶叶放到杯子里,将开水倒入杯中,等茶叶泡好。
问题:开车。
其中的算法:首先要打开车门,驾驶员坐好,插上车钥匙,发动汽车。
‘柒’ C语言编程程序的算法描述
#include<stdio.h>
#define N 4
int set1(i?nt a[][N],int n)
{
int i,j,sum=0;
for(i=0;i<n;i++)
{
//将二维数组中的对角线全部设置数为1
a[i][i]=1;
a[n-1-i][i]=1;
}
for(i=0;i<n;i++)
for(j=0;j<n;j++)
if(!(i==j ||i+j==n-1))
{
sum+=a[i][j];//求数组中除对角线以外所有元素之和
}
return sum;
}
void main()
{
int n=4,a[N][N],i,j,sum;
for(i=0;i<n;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);//声明一个数组,并给它赋值
sum=set1(a,n);//调用set1()函数,重新设置数组中元素
printf("%d \n",sum);
}
希望对你有帮助,望采纳,祝你学习愉快
‘捌’ c语言程序设计的算法用伪代码描述过程是怎样的
就是不是很符合C语言的编码规范,把算法的过程描述出来,可以用中文,英文,或者不全的代码。都可以