当前位置: 首页>>代码示例>>C++>>正文


C++ Poly::back方法代码示例

本文整理汇总了C++中Poly::back方法的典型用法代码示例。如果您正苦于以下问题:C++ Poly::back方法的具体用法?C++ Poly::back怎么用?C++ Poly::back使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Poly的用法示例。


在下文中一共展示了Poly::back方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: divide

Poly divide(Poly const &a, Poly const &b, Poly &r) {
	Poly c;
	r = a; // remainder
	assert(!b.empty());

	const unsigned k = a.degree();
	const unsigned l = b.degree();
	c.resize(k, 0.);

	for(unsigned i = k; i >= l; i--) {
		assert(i >= 0);
		double ci = r.back()/b.back();
		c[i-l] += ci;
		Poly bb = ci*b;
		//std::cout << ci <<"*(" << b.shifted(i-l) << ") = "
		//          << bb.shifted(i-l) << "     r= " << r << std::endl;
		r -= bb.shifted(i-l);
		r.pop_back();
	}
	//std::cout << "r= " << r << std::endl;
	r.normalize();
	c.normalize();

	return c;
}
开发者ID:luzpaz,项目名称:scribus,代码行数:25,代码来源:poly.cpp

示例2: reduce

void reduce(Poly &v)
{
  while (!v.empty() && v.back() % MOD == 0)
  {
    v.pop_back();
  }
}
开发者ID:kazunetakahashi,项目名称:atcoder,代码行数:7,代码来源:T.cpp

示例3: laguerre_internal_complex

cdouble laguerre_internal_complex(Poly const & p,
                                  double x0,
                                  double tol,
                                  bool & quad_root) {
    cdouble a = 2*tol;
    cdouble xk = x0;
    double n = p.degree();
    quad_root = false;
    const unsigned shuffle_rate = 10;
//    static double shuffle[] = {0, 0.5, 0.25, 0.75, 0.125, 0.375, 0.625, 0.875, 1.0};
    unsigned shuffle_counter = 0;
    while(std::norm(a) > (tol*tol)) {
        //std::cout << "xk = " << xk << std::endl;
        cdouble b = p.back();
        cdouble d = 0, f = 0;
        double err = abs(b);
        double abx = abs(xk);
        for(int j = p.size()-2; j >= 0; j--) {
            f = xk*f + d;
            d = xk*d + b;
            b = xk*b + p[j];
            err = abs(b) + abx*err;
        }

        err *= 1e-7; // magic epsilon for convergence, should be computed from tol

        cdouble px = b;
        if(abs(b) < err)
            return xk;
        //if(std::norm(px) < tol*tol)
        //    return xk;
        cdouble G = d / px;
        cdouble H = G*G - f / px;

        //std::cout << "G = " << G << "H = " << H;
        cdouble radicand = (n - 1)*(n*H-G*G);
        //assert(radicand.real() > 0);
        if(radicand.real() < 0)
            quad_root = true;
        //std::cout << "radicand = " << radicand << std::endl;
        if(G.real() < 0) // here we try to maximise the denominator avoiding cancellation
            a = - sqrt(radicand);
        else
            a = sqrt(radicand);
        //std::cout << "a = " << a << std::endl;
        a = n / (a + G);
        //std::cout << "a = " << a << std::endl;
        if(shuffle_counter % shuffle_rate == 0)
		{
			//a *= shuffle[shuffle_counter / shuffle_rate];
		}
        xk -= a;
        shuffle_counter++;
        if(shuffle_counter >= 90)
            break;
    }
    //std::cout << "xk = " << xk << std::endl;
    return xk;
}
开发者ID:AlterScribus,项目名称:ece15,代码行数:59,代码来源:poly-laguerre-solve.cpp

示例4: monic

Poly monic(Poly p)
{
  reduce(p);
  if (is_zero(p))
  {
    return p;
  }
  ll m = p.back();
  ll rev_m = mod_rev(m);
  return rev_m * p;
}
开发者ID:kazunetakahashi,项目名称:atcoder,代码行数:11,代码来源:T.cpp

示例5: onEdge

inline bool onEdge(const Point & point, const Poly & poly, const Edges & edges, const S & eps)
{
    for(auto j = edges.begin(), jend = edges.end(); j != jend; ++j)
    {
        auto & p1 = poly[*j];
        auto & p2 = *j == 0 ? poly.back() : poly[*j - 1];
        if(onEdge(point, p1, p2, eps))
            return true;
    }
    return false;
}
开发者ID:go4and,项目名称:lib,代码行数:11,代码来源:math.hpp

示例6: within

inline bool within(const Point & point, const Poly & poly, const Mapping & mapping, const S & ieps)
{
    auto i = std::lower_bound(mapping.begin(), mapping.end(), point.y, detail::CmpY<decltype(*mapping.begin())>());
    if(i == mapping.begin())
    {
        if(ieps < 0 || point.y < i->y - ieps)
            return false;
        return onEdge(point, poly, i->edges, ieps);
    }
    if(i == mapping.end())
    {
        if(ieps < 0)
            return false;
        --i;
        if(point.y > i->y + ieps)
            return false;
        if(!i->edges.empty() && onEdge(point, poly, i->edges, ieps))
            return true;
        --i;
        return onEdge(point, poly, i->edges, ieps);
    }
    S eps = std::abs(ieps);
    if(i->y - point.y < eps)
    {
        if(onEdge(point, poly, i->edges, eps))
            return ieps > 0;
    }
    --i;
    if(onEdge(point, poly, i->edges, eps))
        return ieps > 0;
    bool result = false;
    for(auto j = i->edges.begin(), jend = i->edges.end(); j != jend; ++j)
    {
        auto & p1 = poly[*j];
        auto & p2 = *j == 0 ? poly.back() : poly[*j - 1];
        auto d = p2.y - p1.y;
        if(std::abs(d) > eps)
        {
            auto t = (point.y - p1.y) / d;
            if(point.x + eps > p1.x + (p2.x - p1.x) * t)
                result = !result;
        }
    }
    return result;
}
开发者ID:go4and,项目名称:lib,代码行数:45,代码来源:math.hpp

示例7: contains

bool contains(const Poly & poly, const Point & p)
{
    bool result = false;
    const auto * prev = &poly.back();
    for(auto i = poly.begin(), end = poly.end(); i != end; ++i)
    {
        const auto * cur = &*i;
        if(cur->y > prev->y)
        {
            auto dy = cur->y - prev->y;
            if(p.y >= prev->y && p.y < cur->y &&
               (p.x - prev->x) * dy <= (p.y - prev->y) * (cur->x - prev->x))
               result = !result;
        } else {
            auto dy = cur->y - prev->y;
            if(p.y < prev->y && p.y >= cur->y &&
               (p.x - prev->x) * dy >= (p.y - prev->y) * (cur->x - prev->x))
               result = !result;
        }
        prev = cur;
    }
    return result;
}
开发者ID:go4and,项目名称:lib,代码行数:23,代码来源:math.hpp

示例8: is_monic

bool is_monic(const Poly &p)
{
  return (p.back() == 1);
}
开发者ID:kazunetakahashi,项目名称:atcoder,代码行数:4,代码来源:T.cpp

示例9: tidy

// Simplify the polynomial, eliminates the high-degree zero term.
void tidy(Poly& c) {
    while(c.size() > 1 && fabs(c.back()) < EPS)
        c.pop_back();
}
开发者ID:3013216027,项目名称:zoj-solutions-fish_ball,代码行数:5,代码来源:p1478.cpp

示例10: tidy

// Simplify the polynomial, eliminates the high-degree zero term.
void tidy(Poly& c) {
    while(!c.empty() && c.back() == 0)
        c.pop_back();
}
开发者ID:3013216027,项目名称:zoj-solutions-fish_ball,代码行数:5,代码来源:p2707.cpp


注:本文中的Poly::back方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。