- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我制作的这个质因数分解程序运行得非常好。唯一的问题是,当输入很大时,它会卡住浏览器。我的目标是让整个计算持续更长时间,而不是卡住浏览器。我尝试了几种方法来解决这个问题。首先,我尝试使用async
+ await sleep(ms)
(我在for循环中输入await sleep,因为我认为它们导致了过度计算问题)但是由于某种未知的原因,它根本没有给出答案。我还尝试将函数拆分为三个较小的函数(每个 for
循环一个),并为每个函数使用 setTimeout
,但这效果不佳。我知道,可能有更简单的素因数分解程序,但我想研究这个程序,因为我自己找到了它。顺便说一句,调用的第一个函数是 factor1(num)
function factor1(num) {
if (primecheck(num)){
document.getElementById("resultingz").innerHTML = num + " is prime";
}else{
var finalito = [];
factor2(num, finalito);
document.getElementById("resultingz").innerHTML = finalito.toString();
}
}
function factor2(num, arrada){
var factors = [];
var factornums = [];
for (coun = 2; coun <= num/2; coun++) {
if (num % coun == 0) factornums.push(coun);
}
for (i=0; i < factornums.length; i++){
if (primecheck(factornums[i])){
factors.push(factornums[i]);
}
}
for (i = 0; i < factors.length; i++){
rightnow = factors[i];
while (num % rightnow == 0) {
arrada.push(factors[i]);
rightnow = rightnow * factors[i];
}
}
}
function primecheck(num){
var primestate = true;
for (coun = 2; coun <= Math.sqrt(num); coun++) {
if (num % coun == 0) primestate = false;
}
return primestate;
}
最佳答案
一些改进:
function factor2(num, arrada){
for (coun = 2; coun <= num/2; coun++) {//one loop instead of three
if (num % coun == 0 && primecheck(coun)){
var rightnow=coun;
while (num % rightnow == 0) {
arrada.push(coun);
rightnow = rightnow * coun;
}
}
}
}
function primecheck(num){
var primestate = true,num=Math.sqrt(num);//performance improvement
for (var coun = 2; coun <=num; coun++) {
if (num % coun == 0){
primestate = false;
break;//stop loop if false found
}
}
return primestate;
}
如果替换简单的 for 循环,您可以轻松地异步循环:
for(var counter=start;counter<max;counter++){
code;
}
end();
使用伪递归函数:
(function iterate (counter){
if(counter>=max) return end();//end is a callback
code;
setTimeout(iterate,0,counter+1);//next tick, continue with counter+1
})(start);//start the function with a start value
关于Javascript 质因数分解代码因大量数字而卡住,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45327089/
我正在我的 xamarin.forms 应用程序中实现扫描仪功能,为此我正在使用 iOS native AVCaptureSession。但我的问题是在扫描或捕获 session 处于事件状态并且设备
所以我目前正在为我的项目制作一个音乐应用程序,它允许用户创建自己的音乐播放列表。但是,当我单击显示媒体选择器按钮时,它只显示白屏,当包含媒体选择器的 View 是 Initial View Contr
当我尝试在模拟器中启动 AVD 时,会出现一个小窗口(见图片),5 秒后它说没有响应并一直保持这种状态直到我关闭它。 我在网上搜索并尝试了所有解决方案,但都没有成功 在 BIOS 中启用了虚拟化 已安
尝试使用以下命令从视频中提取特定帧(删除了文件的特定名称!: ffmpeg -i video.mp4 -vf "select-gte(n\,6956)"-vframes 10262 文件夹/帧%d.j
我怎么知道终端正在继续工作而不中断它? 我已经运行了以下 git 命令: clone git://ligo-vcs.phys.uwm.edu/lalsuite.gituote 一段时间后它似乎被卡住了
我对 WPF 中的数据网格有一个奇怪的问题。我正在为我的应用程序使用 MVVM 模式,并且我的 View 模型实现了 idataerrorinfo 接口(interface)。每当我在添加新行后在我的
我有这个 Excel 文件,当我输入数据时它卡住了。例如,我双击一个单元格,输入数据,然后按“输入”。它会卡住而不是进入下面的细胞。按几次“enter”不会解冻程序,唯一有效的是用鼠标选择另一个单元格
我有线程池的任务队列,每个任务都有卡住锁定其正在使用的所有资源的倾向。并且除非重新启动服务,否则这些无法释放。 ThreadPool 中有没有办法知道它的线程已经被卡住?我有一个使用超时的想法(虽然我
我制作了以下小程序来确定内存是否用于 freeze(X,Goal) 之类的目标回收时 X变得无法访问: %:- use_module(library(freeze)). % Ciao Prolog n
我有一个使用 swing 的简单 java 应用程序。然而,当我执行程序时,框架将会出现,但我无法单击任何地方,并且按钮仅在几秒钟后出现。我对 javas Swing 库非常陌生,所以我可能会丢失一些
我正在尝试创建一个简单的 TCP 客户端服务器应用程序接口(interface)用户可以在按下相应按钮时启动或停止服务器我创建了一个 StartServer 按钮,当用户按下按钮时它应该连接到服务
我正在尝试从 ftp 服务器下载文件,但在检索文件时卡住了。我正在使用 commons-net-3.6.jar 我注意到的事情 当我使用 ftpClient.enterRemotePassiveMod
我正在尝试编写一个函数,该函数将能够找到位于我系统上的可执行文件搜索路径中的任意可执行文件。我遇到了一些输入会导致 SearchPathW 的问题无限期地卡住,我不确定到底发生了什么。 std::op
我的 Nativescript 应用程序的许多页面中都有 RadSideDrawer。主应用程序组件有一个 page-router-outlet并且所有其他页面都通过导航加载到此组件中。带抽屉的页面包
我有一个最小的服务器,它等待客户端连接,然后他启动一个线程,将回复发送回客户端,问题是回复。 这是服务器的代码: int port = 1234; ServerSocket servSock =
我有一个使用 C# 的 WinForms 应用程序。我尝试从文件中读取一些数据并将其插入到数据表中。虽然此操作很忙,但我的表单卡住并且我无法移动它。有谁知道我该如何解决这个问题? 最佳答案 这可能是因
在我们学校最新的项目中,我遇到了一些问题。我想观察新条目的路径,该路径是由文件导向器按钮选择的,但如果我选择任何文件,整个窗口都会卡住...我猜它被卡住,因为调用了“observePath”方法,但我
当我输入一百万作为输入数字时,我的程序卡住了。我该如何解决这个问题? 我尝试将第二个 for 循环分离为第二个函数,但没有成功。 import java.io.*; public class Arra
早上好编译我的应用程序时,我在 Android Studio 上遇到问题。我在构建时没有收到关于 app:transformClassesWithDexBuilderForDebug 的任何输出错误,
我正在使用以下触发器 DELIMITER ; CREATE TRIGGER updateCount AFTER INSERT ON user_info FOR EACH ROW BEGIN UPDA
我是一名优秀的程序员,十分优秀!