请人将这个c++程序的功能补充完整
答案:3 悬赏:50 手机版
解决时间 2021-05-05 11:54
- 提问者网友:酱爆肉
- 2021-05-04 18:18
#include <iostream>
using namespace std;
void filter(int *p,int count,int &succeed1);
void taxis(int *p,int count,int succeed1);
int main()
{
int count; //个数
int incept; //接收
int succeed1=0; //判断重复的个数
cin>>count;
int *p=new int[count];
for(int i=0;i<count;i++)
{
incept=rand()%100;
p[i]=incept;
}
for(int z=0;z<count;z++)
{
if(z%10==0&&z>0)
{
cout<<endl;
}
cout<<p[z]<<" ";
}
filter(p,count,succeed1);
taxis(p,count,succeed1);
return 0;
}
void filter(int *p,int count,int &succeed1)
{
int *p2=new int[count];
for(int hh=0;hh<count;hh++)
{
p2[hh]=p[hh];
}
int temporary;
for(int i=0;i<count;i++)
{
for(int j=i+1;j<count;j++)
{
if(p2[i]<p2[j])
{
temporary=p2[i];
p2[i]=p2[j];
p2[j]=temporary;
}
}
}
for(int j=0;j<count;j++)
{
for(int i=j+1;i<count;i++)
{
if(p[j]==p2[i])
{
p[j]=p2[i];
succeed1++;
}
}
}
}
void taxis(int *p,int count,int succeed1)
{int temporary;
cout<<endl<<succeed1<<endl;
for(int i=0;i<count;i++)
{
for(int j=0;j<count;j++)
{
if(p[i]<p[j])
{
temporary=p[i];
p[i]=p[j];
p[j]=temporary;
}
}
}
for(int z=0;z<count;z++)
{
if(z%10==0&&z>0)
{
cout<<endl;
}
cout<<p[z]<<" ";
}
}
(——
实现的功能就是随机输入1000以内的数值 100个以内的数组元素
然后判断随机产生的数值里面有没有重复
如果有重复把重复的个数给数出来!
然后从大到小的输出来!——
)
目前这段程序有两个功能没有实现,第一就是随机数每次出来的数值并不是真的是毫无规律,每次输出来好像都有规律似的!请求高手帮忙将这个BUG给改一下!
另外一个就是判断随机数产生的是否有重复的数值
这个我该了半天,没该好!晕,我也不知道是我的判断的方法问题,还是其他的问题!虽然这些功能好像很简单,但我搞了将近3小时也没弄好,主要原因就是因为这两个问题不知道该怎么解决!
不知道哪位高手能帮忙改一下下!
写的有点儿乱,希望能看明白啥意思
最佳答案
- 五星知识达人网友:鸠书
- 2021-05-04 19:15
使用rand函数,记得加上srand( (unsigned)time( NULL ) ); 否则你上次运行产生的随机数会和这次运行产生的随机数一样。
全部回答
- 1楼网友:独行浪子会拥风
- 2021-05-04 21:28
#include <ctime>
#include <iostream>
using namespace std;
void filter(int *p,int count,int &succeed1);
void taxis(int *p,int count,int succeed1);
int main(int argc, char* argv[])
{
int count; //个数
int incept; //接收
int succeed1=0; //判断重复的个数
cin>>count;
srand((unsigned)time(NULL));
int *p=new int[count];
for(int i=0;i<count;i++)
{
incept=rand()%100;
p[i]=incept;
}
for(int z=0;z<count;z++)
{
if(z%10==0&&z>0)
{
cout<<endl;
}
cout<<p[z]<<" ";
}
filter(p,count,succeed1);
taxis(p,count,succeed1);
return 0;
}
void filter(int *p,int count,int &succeed1)
{
int *p2=new int[count];
for (int i = 0; i < count; i++)
{
p2[i] = 0;
}
for (int j = 0; j < count; j++)
{
p2[p[j]]++ ;
}
for (int m = 0; m < count; m++)
{
if (p2[m] > 1)
{
succeed1 += p2[m];
}
}
}
void taxis(int *p,int count,int succeed1)
{
int temporary;
cout << endl << "------------------>" << succeed1 << endl;
for(int i=0;i<count;i++)
{
for(int j=0;j<count;j++)
{
if(p[i]<p[j])
{
temporary=p[i];
p[i]=p[j];
p[j]=temporary;
}
}
}
for(int z=0;z<count;z++)
{
if(z%10==0&&z>0)
{
cout<<endl;
}
cout<<p[z]<<" ";
}
cout<<endl;
}
- 2楼网友:上分大魔王
- 2021-05-04 20:46
#include <ctime>
#include <iostream>
using namespace std;
void filter(int *p,int count,int &succeed1);
void taxis(int *p,int count,int succeed1);
int main(int argc, char* argv[])
{
int count; //个数
int incept; //接收
int succeed1=0; //判断重复的个数
cin>>count;
srand((unsigned)time(NULL));
int *p=new int[count];
for(int i=0;i<count;i++)
{
incept=rand()%100;
p[i]=incept;
}
for(int z=0;z<count;z++)
{
if(z%10==0&&z>0)
{
cout<<endl;
}
cout<<p[z]<<" ";
}
filter(p,count,succeed1);
taxis(p,count,succeed1);
return 0;
}
void filter(int *p,int count,int &succeed1)
{
int *p2=new int[count];
for (int i = 0; i < count; i++)
{
p2[i] = 0;
}
for (int j = 0; j < count; j++)
{
p2[p[j]]++ ;
}
for (int m = 0; m < count; m++)
{
if (p2[m] > 1)
{
succeed1 += p2[m];
}
}
}
void taxis(int *p,int count,int succeed1)
{
int temporary;
cout << endl << "------------------>" << succeed1 << endl;
for(int i=0;i<count;i++)
{
for(int j=0;j<count;j++)
{
if(p[i]<p[j])
{
temporary=p[i];
p[i]=p[j];
p[j]=temporary;
}
}
}
for(int z=0;z<count;z++)
{
if(z%10==0&&z>0)
{
cout<<endl;
}
cout<<p[z]<<" ";
}
cout<<endl;
}
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯