法一:利用循环判断
思路:首先对特殊数字0和1进行判断,接着使用一个for循环里面的变量i从2开始,同时定义一个count计数器来记录每次num是否能整除别的数。若能count计数器会加加,说明有数可以被整除不是素数,若count恒等于0,则说明没有数可以被整除是素数。
var num = prompt("输入一个数字");
if (num == 1 || num == 0) {
alert(num + "不为素数");
}
for (var i = 2; i < num; i++) {
var count = 0; //默认没有被整除
if (num % i == 0) {
//表示有数可以整除
count++;
break;
}
}
if (count == 0) {
alert(num + "为素数");
} else {
alert(num + "不为素数");
}
法二:利用函数
思路:0和1的判断同上,for循环里面采用了"非黑即白"的思想,首先使用循环条件判断不是素数,若是素数直接跳出循环,进行return返回值即可,最后对函数进调用。
function su() {
var num = prompt("输入一个数字");
if (num == 1 || num == 0) {
return num + "不是素数";
}
for (var i = 2; i < num; i++) {
if (num % i == 0) {
//非黑即白
return num + "不是素数";
}
}
return num + "是素数";
}
var result = su();
alert(result);
输出100-200之间所有的质数 100是不是质数
思路:使用双循环,外层循环用来遍历100-200之间所有的数字,内层循环用来遍历1-i之间所有的数字。定义一个变量来记录1-i之间能被整除的次数,若变量的值恒为0,则说明没有可被i整除的数字,也即为素数。
for (var i = 100; i <= 200; i++) {
var time = 0;//记录 i 除以 1-i之间的数字 能被整除次
for (var j = 2; j < i; j++) {//循环出1-i 之间的所有的数字
if (i % j == 0) {
time++;
}
}
if (time == 0) {
console.log(i);
}
}