用随机函数产生10个互不相同的两位整数,存放到一维数组中.并输出其中的素数.

#include<iostream.h>#include<time.h>#include<math.h>#include<stdlib.h>voidmain(){inta... #include<iostream.h>
#include<time.h>
#include<math.h>
#include<stdlib.h>

void main()
{
int a[10],m;
srand(time(0));
int n;
for( n=0;n<10;n++)
{
a[n]=rand()%100;

while(a[n]<10)
{
a[n]=rand()%100;
}

}
for(n=0;n<10;n++)
{
m=n+1;
for(;m<10;m++)
{
while(a[n]==a[m])
{
a[m]=rand()%100;
}

}

}
cout<<"所产生的10个互不相同的二位随机整数为: "<<endl;
for(n=0;n<10;n++)
{

cout<<a[n]<<" ";
}
cout<<endl;

cout<<"其中的素数为: ";

for(n=0;n<10;n++)
{
m=2;
while(m<=(int)sqrt(a[n]) && a[n]%m!=0)
{

m++;
}

if(m>(int)sqrt(a[n]))
cout<<a[n]<<" ";

}
cout<<endl;

}

我这样写可以吗??有什么地方有必要优化下吗???
我不知道我这样写所产生两位随机整数会不会有不是两位数的??
展开
 我来答
wonder想知道
推荐于2017-12-16 · TA获得超过231个赞
知道小有建树答主
回答量:113
采纳率:0%
帮助的人:172万
展开全部
有一点瑕疵,生成两位数的地方有点错误,判断有无重复数的地方也有点错误,而且可以进行简化。修改了的地方我做了注释。(粘贴过来时出错了,我重新粘贴了下)

#include<iostream>
#include<time.h>
#include<math.h>
#include<stdlib.h>
using namespace std;
void main()
{
int a[10],m;
srand(time(0));
int n;
int i;
for( n=0;n<10;n++)
{
a[n]=rand()%90+10; //这样产生的数一定是个两位的整数
for(i=0;i<n;i++)//用这个循环来判断有无重复的数
if(a[n]==a[i]) { n--; break; }//如果有重复的数,则重新生成一个数,并重新判断有无重复的数
}
/*这段程序作废
while(a[n]<10)
{
a[n]=rand()%100;
}

for(n=0;n<10;n++)
{
m=n+1;
for(;m<10;m++)
{
while(a[n]==a[m])
{
a[m]=rand()%100;
}

}

} 这段程序作废*/
cout<<"所产生的10个互不相同的二位随机整数为: "<<endl;
for(n=0;n<10;n++)
{

cout<<a[n]<<" ";
}
cout<<endl;

cout<<"其中的素数为: ";

for(n=0;n<10;n++)
{
m=2;
while(m<=(int)sqrt((double)a[n]) && a[n]%m!=0) //加上(double)
{

m++;
}

if(m>(int)sqrt((double)a[n])) //加上(double)
cout<<a[n]<<" ";

}
cout<<endl;
}

运行结果:
所产生的10个互不相同的二位随机整数为:
40 54 89 65 56 22 63 94 17 59
其中的素数为: 89 17 59
请按任意键继续. . .
创作者q6YJIqvEnw
2019-08-01 · TA获得超过3.1万个赞
知道大有可为答主
回答量:1.2万
采纳率:33%
帮助的人:624万
展开全部
#include
#include
#include
#include
//大致没有问题了
不过检查有无相同数字的算法有问题,这样不能就消除重复数字,知识说几率减少很多
void
main()
{
int
a[10],m;
srand(time(0));
int
n;
for(
n=0;n<10;n++)
{
a[n]=rand()%100;
//需要使用a[m]=rand()%100+1;
才是1-100内
while(a[n]<10)
{
a[n]=rand()%100;
//需要使用a[m]=rand()%100+1;
才是1-100内
}
}
for(n=0;n<10;n++)
{
m=n+1;
for(;m<10;m++)
{
while(a[n]==a[m])
{
a[m]=rand()%100;
//需要使用a[m]=rand()%100+1;
才是1-100内
}
}
}
cout<<"所产生的10个互不相同的二位随机整数为:
"<
(int)sqrt(a[n]))
cout<
评论
0
0
加载更多
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
创作者BIMKXUv5Jg
2019-03-02 · TA获得超过2.9万个赞
知道小有建树答主
回答量:1.2万
采纳率:28%
帮助的人:942万
展开全部
有一点瑕疵,生成两位数的地方有点错误,判断有无重复数的地方也有点错误,而且可以进行简化。修改了的地方我做了注释。(粘贴过来时出错了,我重新粘贴了下)
#include
#include
#include
#include
using
namespace
std;
void
main()
{
int
a[10],m;
srand(time(0));
int
n;
int
i;
for(
n=0;n<10;n++)
{
a[n]=rand()%90+10;
//这样产生的数一定是个两位的整数
for(i=0;i
(int)sqrt((double)a[n]))
//加上(double)
cout<
评论
0
0
加载更多
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
pujia12345
2008-06-19 · TA获得超过3680个赞
知道大有可为答主
回答量:3456
采纳率:0%
帮助的人:3037万
展开全部
#include<iostream.h>
#include<time.h>
#include<math.h>
#include<stdlib.h>
//大致没有问题了 不过检查有无相同数字的算法有问题,这样不能就消除重复数字,知识说几率减少很多
void main()
{
int a[10],m;
srand(time(0));
int n;
for( n=0;n<10;n++)
{
a[n]=rand()%100; //需要使用a[m]=rand()%100+1; 才是1-100内

while(a[n]<10)
{
a[n]=rand()%100; //需要使用a[m]=rand()%100+1; 才是1-100内
}

}
for(n=0;n<10;n++)
{
m=n+1;
for(;m<10;m++)
{
while(a[n]==a[m])
{
a[m]=rand()%100; //需要使用a[m]=rand()%100+1; 才是1-100内
}

}

}
cout<<"所产生的10个互不相同的二位随机整数为: "<<endl;
for(n=0;n<10;n++)
{

cout<<a[n]<<" ";
}
cout<<endl;

cout<<"其中的素数为: ";

for(n=0;n<10;n++)
{
m=2;
while(m<=(int)sqrt(a[n]) && a[n]%m!=0)
{

m++;
}

if(m>(int)sqrt(a[n]))
cout<<a[n]<<" ";

}
cout<<endl;

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
庹忆远7A
2008-06-19 · 贡献了超过345个回答
知道答主
回答量:345
采纳率:0%
帮助的人:0
展开全部
5353
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式