永发信息网

请人将这个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; }

我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯