本文整理汇总了C++中Polynomial::is_zero方法的典型用法代码示例。如果您正苦于以下问题:C++ Polynomial::is_zero方法的具体用法?C++ Polynomial::is_zero怎么用?C++ Polynomial::is_zero使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Polynomial
的用法示例。
在下文中一共展示了Polynomial::is_zero方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: while
Polynomial<int> Polynomial<int>::gcd(
const Polynomial<int>& p1, const Polynomial<int>& p2)
{ CGAL_NEF_TRACEN("gcd("<<p1<<" , "<<p2<<")");
if ( p1.is_zero() ) {
if ( p2.is_zero() ) return Polynomial<int>(int(1));
else return p2.abs();
}
if ( p2.is_zero() )
return p1.abs();
Polynomial<int> f1 = p1.abs();
Polynomial<int> f2 = p2.abs();
int f1c = f1.content(), f2c = f2.content();
f1 /= f1c; f2 /= f2c;
int F = CGAL::gcd(f1c,f2c);
Polynomial<int> q,r; int M=1,D;
bool first = true;
while ( ! f2.is_zero() ) {
Polynomial<int>::pseudo_div(f1,f2,q,r,D);
if (!first) M*=D;
CGAL_NEF_TRACEV(f1);CGAL_NEF_TRACEV(f2);CGAL_NEF_TRACEV(q);CGAL_NEF_TRACEV(r);CGAL_NEF_TRACEV(M);
r /= r.content();
f1=f2; f2=r;
first=false;
}
CGAL_NEF_TRACEV(f1.content());
return Polynomial<int>(F)*f1.abs();
}