c++(栈)的编程 急急急急急急啊 在线等

对于一个给定的整数n>1,最小的整除n的整数d>1是一个素因子。如果得到d,然后将n替换成n被d整除后的商,并重复这个过程,直到n变成1为止,则可以得到n的素因子分解。编... 对于一个给定的整数n>1,最小的整除n的整数d>1是一个素因子。如果得到d,然后将n替换成n被d整除后的商,并重复这个过程,直到n变成1为止,则可以得到n的素因子分解。编写一个程序以这种方式来求出n的素因子分解,但是要将素因子按照降序来显示。例如,对于n=3960,程序应该产生
11*5*3*3*2*2*2

请用栈实现,简单一点~ 只要有push、top、pop,然后实现功能就行,越简单越好。急啊!!!
展开
 我来答
zy1404
推荐于2016-10-31 · TA获得超过1387个赞
知道小有建树答主
回答量:784
采纳率:100%
帮助的人:466万
展开全部
#include<iostream>
#include<stack>
using namespace std;
int sushu(int n)
{
int i;
for(i=2;i<n;i++)
{
if(n%i==0)
break;
}
if(n==i && n!=1)
return 1;
else
return 0;
}
int main()
{
int n,i,j;
stack<int> mystack;
cin>>n;
while(n>1)
{
for (i=2;i<=n;i++)
{
if (n%i==0 &&sushu(i)==1)
{
mystack.push(i);
n=n/i;
break;
}
}
}
while(!mystack.empty())
{
cout<<mystack.top()<<" ";
mystack.pop();
}
return 0;
}
更多追问追答
追问
谢谢,不过能不能帮忙再改改?
改成

class MyHuiWen
{
private:
****
public:
void push();
void pop();
void top();

******//实现功能的函数
};

拜托你了
追答
#include<iostream>
#include<stack>
using namespace std;
class  MyHuiWen
{
stack<int> mystack;
int n;
public:
MyHuiWen(int );
int Sushu(int);
void push(int);
void pop();
int top();
int empty();
};
MyHuiWen::MyHuiWen(int m)
{
n=m;
}
int MyHuiWen::Sushu(int n)
{
int i;
for(i=2;i<n;i++)
{
if(n%i==0)
break;
}
if(n==i && n!=1)
return 1;
else
return 0;
}
void MyHuiWen::push(int n)
{
mystack.push(n);
}
int MyHuiWen::top()
{
return mystack.top();
}
void MyHuiWen::pop()
{
mystack.pop();
}
int MyHuiWen::empty()
{
return mystack.empty();
}
int main()
{
int n,i,j;
cin>>n;
MyHuiWen H(n);
while(n>1)
{
for (i=2;i<=n;i++)
{
if (n%i==0 &&H.Sushu(i)==1)
{
H.push(i);
n=n/i;
break;
}
}
}
while(!H.empty())
{
cout<<H.top()<<" ";
H.pop();
}
return 0;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式