算法死循环
㈠ C语言中什么叫死循环怎么避免
死循环就是不停的执行for循环,while循环。
避免死循环要看下死循环是如何产生的,
例如在C语言程序中,语句“while(1)printf("*");”就是一个死循环,运行它将无休止地打印*号。
产生死循环的情况有:
▪ 逻辑错误
▪ 变量处理错误
▪ 奥尔德森循环
▪ 无穷递归
你可以看下这些死循环出现的原因,然后在开发中避免一下。
㈡ matlab算法进入死循环
并不是死循环,只是循环的次数比较多,你没有等到它算完而已。
当你强制中断时,也未必每次都在同一个地方,比如这行代码
h=h+eval(G);
就有两处,一处在 for k=1:100 循环内,另一处在 for k=2:e,for r=1:100 的循环内。除了这两行之外,还有一行比较耗时间,是 u1=u1+eval(g)*Z(:,j)。
这三行代码都是调用了符号运算,而且循环次数比较多(粗略估算,分别为30万、120万、30万次),差不多99%的运算时间都消耗在这三行代码上了,所以,当你强制中断时,刚好落在这三行上的概率非常大。
再耐心等一会儿,应该能够算完的。不过,就代码而言,应该可以进一步优化的,不是必须要等那么久的。
㈢ 算法的有穷性和死循环
看你写出while(1),那么你一定是在用程序来实现算法。
首先你要明确知道算法不只有程序实现。
其次,你要了解算法在计算机系统中处于哪个层次?
计算机系统实现
你可以了解一下计算机系统的演变,目前的计算机系统都是按照这种层次转换去设计的。
a)问题,也就是我们经常项目中遇到的需求文档,这些都是用自然语言来描述的,什么是自然语言?就是汉语、英语等这些人说的话。
b)算法,算法我们可以用自然语言,流程图,伪代码等来描述,这就是所谓项目详细设计,算法的大特性:
有穷性:一个算法在执行有限步骤后,在有限时间内能够实现的。
明确性:算法中每一个步骤的表述都应该是确定的、没有歧义的语句。
可计算性:算法的可行性就是指每一个步骤都能够有效地执行,并得到确定的结果,而且能够用来方便地解决一类问题。
如果算法违背了这些特性那就不叫算法,这是前人以及众人都认可的。
c)程序,程序就是我们开始码代码了,就是你要按照详细设计去用代码实现,这个时候你发现 详细设计里面写了一段话 让你无限循环即(while(1)),你会不会去揍这个写详细设计的?
后面我就不多说了,总结起来就是 程序不等价于算法,算法可以用程序来实现,程序的设计包含算法,所以你说你的while(1)和算法有穷性矛盾,是八竿子打不到的事情。
㈣ 该算法陷入死循环,如何改正
1、augmentpath,直译为“增广路径”,其思想大致如下:原有网络为G,设有一辅助图G',其定义为V(G')=V(G),E(G')初始值(也就是容量)与E(G)相同。每次操作时从Source点搜索出一条到Sink点的路径,然后将该路径上所有的容量减去该路径上容量的
㈤ C语言中的死循环是什么意思啊
死循环是循环条件永远能够得到满足,循环永远进行下去。这种循环一旦进入就出不来了
所以要设置跳出条件
㈥ 死循环,死递归和死锁对CPU的消耗有什么异同点
死循环,死递归和死锁对CPU的消耗基本相同,但是产生的原因是不一样的。
一、死循环。
例如在VB语言程序中,下列语句:
Do While i=1
print "*"
Loop
就是一个死循环,运行它将无休止地打印*号。
不存在一种算法,对任何一个程序及相应的输入数据,都可以判断是否会出现死循环。因此,任何编译系统都不做死循环检查。
在设计程序时,若遇到死循环,我们可以通过按下Ctrl+Pause/Break的方法,结束死循环。
然而,在编程中死循环并不是一个需要避免的问题,相反,在实际应用中,经常需要用到死循环。例如,我们使用的Windows操作系统下的窗口程序中的窗口都是通过一个叫消息循环的死循环实现的。在单片机、嵌入式编程中也经常要用到死循环。在各类编程语言中,死循环都有多种实现的方法,以C语言为例,可分别使用while.for,goto实现。
二、死锁。
两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。
计算机系统中,如果系统的资源分配策略不当,更常见的可能是程序员写的程序有错误等,则会导致进程因竞争资源不当而产生死锁的现象。
在两个或多个任务中,如果每个任务锁定了其他任务试图锁定的资源,此时会造成这些任务永久阻塞,从而出现死锁。例如:事务A 获取了行 1 的共享锁。事务 B 获取了行 2 的共享锁。
排他锁,等待事务 B 完成并释放其对行 2 持有的共享锁之前被阻塞。
排他锁,等待事务 A 完成并释放其对行 1 持有的共享锁之前被阻塞。
事务 B 完成之后事务 A 才能完成,但是事务 B 由事务 A 阻塞。该条件也称为循环依赖关系:事务 A 依赖于事务 B,事务 B 通过对事务 A 的依赖关系关闭循环。
三、死机及其对策。
无论是死循环还是死锁,都会造成电脑死机现象。
电脑系统在工作中,有时候会出现鼠标停滞、键盘不能输入命令等情况,这时的系统已经不能接收任何命令,这种情况被称为死机,死机可能是多种原因造成的,比如同时运行了过多的应用程序,程序的使用方法错误,电脑中某一硬件的损坏(比如硬盘或者内存)等都可能引起死机。解决的常用方法有:
同时按下键盘上的控制键加换档键加删除键,在显示的列表中单击【启动任务管理器】命令,弹出【任务管理器】对话框,单击出现问题的程序,再单击【结束任务】按钮,所选程序立即结束运行。在大多数情况下,都可以通过上述方法关闭已经失去响应的程序,并且可以继续在Windows10中操作。
如果键盘已经不能输入任何命令,可按下机箱上的复位键,几秒钟后电脑将重新启动。
如果机箱上没有复位键,可以直接按住机箱上的电源开关几秒钟,关闭电脑电源,稍后,再按机箱上的电源开关重新启动电脑即可。
㈦ 简单的递归算法,为什么程序运行会死循环
递归死循环肯定是中止条件错了!看了你的代码while (i < len) {
if (key == a[i]) {
return i;
}
这个地方造成死循环了!因为i的值永远是0;并且a[0]的值与key不相等;所以死循环在这里!
㈧ 死循环怎么解
死循环
(无法靠自身的控制终止的循环)
编辑
在编程中,一个无法靠自身的控制终止的程序称为“死循环”。
例如在C语言程序中,语句“while(1)printf("*");”就是一个死循环,运行它将无休止地打印*号。
不存在一种算法,对任何一个程序及相应的输入数据,都可以判断是否会出现死循环。因此,任何编译系统都不做死循环检查。
在设计程序时,若遇到死循环,我们可以通过按下Ctrl+Pause/Break的方法,结束死循环。
然而,在编程中死循环并不是一个需要避免的问题,相反,在实际应用中,经常需要用到死循环。例如,我们使用的Windows操作系统下的窗口程序中的窗口都是通过一个叫消息循环的死循环实现的。在单片机、嵌入式编程中也经常要用到死循环。在各类编程语言中,死循环都有多种实现的方法,以C语言为例,可分别使用while.for,goto实现。
㈨ “算法和程序都不能是无穷的,否则会进入死循环” 判断是否正确
错误
刚上完课,算法是可以无穷的,程序不能无穷。
比如算π的算法就是无穷的,人类算了这么久仍让没有算明白π是多少,对吧
程序不能无穷这个就不用多说了吧,都无穷了,这程序还有毛线用处,永远都没算完,永远也得不到你要的结果,这能叫程序吗?
那么有人问了,这个π不是无穷的算法,怎么用程序算的。
当然π也是一步一步算出来呗,算法虽然无穷,我们大概先知道了这个程序算多少位,大约是个什么复杂度,然后根据电脑的情况先算能算出来的部分,对吧!
不可能一下一直算,那再牛逼的超级计算机也永远算不完。