题意:给定n,整数序列a和b,整数C,求所有成立的x

n<=1e5,1<=a[i]<=1e3,-1e3<=b[i]<=1e3,1<=C<=1e9

思路:

大概就照每条直线的零点分段,维护一下系数和常数项

特判的地方挺多,精度也要注意,写起来像计算几何

感觉这种麻烦的东西应该有模板

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned int uint;
typedef unsigned long long ull;
typedef pair<int,int> PII;
typedef pair<ll,ll> Pll;
typedef vector<int> VI;
typedef vector<PII> VII;
#define N 1100000
#define M 4100000
#define fi first
#define se second
#define MP make_pair
#define pi acos(-1)
#define mem(a,b) memset(a,b,sizeof(a))
#define rep(i,a,b) for(int i=(int)a;i<=(int)b;i++)
#define per(i,a,b) for(int i=(int)a;i>=(int)b;i--)
#define lowbit(x) x&(-x)
#define Rand (rand()*(1<<16)+rand())
#define id(x) ((x)<=B?(x):m-n/(x)+1)
#define ls p<<1
#define rs p<<1|1 const ll MOD=,inv2=(MOD+)/;
double eps=1e-;
int INF=1e9; struct arr
{
ll a,b;
}c[N],ans[N]; bool cmp(arr a,arr b)
{
return a.b*b.a>b.b*a.a;
} ll read()
{
ll v=,f=;
char c=getchar();
while(c<||<c) {if(c=='-') f=-; c=getchar();}
while(<=c&&c<=) v=(v<<)+v+v+c-,c=getchar();
return v*f;
} ll gcd(ll x,ll y)
{
if(y==) return x;
return gcd(y,x%y);
} int xiaoyu(ll x1,ll y1,ll x2,ll y2)
{
//printf("xiaoyu %I64d %I64d %I64d %I64d\n",x1,y1,x2,y2);
int p=-;
ll t=x1*y2-y1*x2;
if(t==) return ;
if(t<) p=-p;
if(y1*y2<) p=-p;
return (p==);
} int main()
{
//freopen("1.in","r",stdin);
int cas=read();
while(cas--)
{
int n;
scanf("%d",&n);
ll C=read();
rep(i,,n)
{
c[i].a=read();
c[i].b=read();
}
sort(c+,c+n+,cmp);
//rep(i,1,n) printf("%I64d %I64d\n",c[i].a,c[i].b);
int m=;
ll sa=,sb=;
rep(i,,n)
{
sa-=c[i].a;
sb-=c[i].b;
}
//printf("sa=%I64d C-sb=%I64d\n",sa,C-sb);
int flag=;
if(sa==&&C-sb==) flag=;
if(xiaoyu(C-sb,sa,-c[].b,c[].a))
{
if(sa==&&C-sb!=) continue;
m++;
ll t=gcd(abs(C-sb),abs(sa));
//printf("t=%I64d\n",t);
ans[m].a=(C-sb)/t;
ans[m].b=sa/t;
if(ans[m].b<)
{
ans[m].a=-ans[m].a;
ans[m].b=-ans[m].b;
}
}
c[n+].a=-1e15; c[n+].b=;
rep(i,,n)
{
sa+=2ll*c[i].a;
sb+=2ll*c[i].b;
//printf("sa=%I64d C-sb=%I64d\n",sa,C-sb);
if(sa==&&C-sb==)
{
flag=;
break;
}
if(sa==&&C-sb!=) continue;
if(xiaoyu(C-sb,sa,-c[i].b,c[i].a)==&&xiaoyu(C-sb,sa,-c[i+].b,c[i+].a))
{
if(m>=&&(C-sb)*ans[m].b==sa*ans[m].a) continue;
m++;
ll t=gcd(abs(C-sb),abs(sa));
ans[m].a=(C-sb)/t;
ans[m].b=sa/t;
if(ans[m].b<)
{
ans[m].a=-ans[m].a;
ans[m].b=-ans[m].b;
}
}
}
if(flag)
{
printf("-1\n");
continue;
}
if(m==)
{
printf("0\n");
continue;
} printf("%d ",m);
rep(i,,m-) printf("%I64d/%I64d ",ans[i].a,ans[i].b);
printf("%I64d/%I64d\n",ans[m].a,ans[m].b);
} return ;
}

【HDOJ6627】equation(模拟)的更多相关文章

  1. 第七届河南省赛F.Turing equation(模拟)

    10399: F.Turing equation Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 151  Solved: 84 [Submit][St ...

  2. [NOIP10.6模拟赛]2.equation题解--DFS序+线段树

    题目链接: 咕 闲扯: 终于在集训中敲出正解(虽然与正解不完全相同),开心QAQ 首先比较巧,这题是\(Ebola\)出的一场模拟赛的一道题的树上强化版,当时还口胡出了那题的题解 然而考场上只得了86 ...

  3. 基于网格的波动方程模拟(Wave equation on mesh)附源码

    波动方程是偏微分方程 (PDE) 里的经典方程,它在物理学中有大量应用并经常用来解释空间中的能量传播.波动方程是一个依赖时间的方程,它解释了系统状态是如何随着时间的推移而发生变化.在下面模拟波动方程时 ...

  4. Fabricate equation(dfs + 模拟)

    Fabricate equation Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Other ...

  5. UVA 1661 Equation (后缀表达式,表达式树,模拟,实现)

    题意:给出一个后缀表达式f(x),最多出现一次x,解方程f(x) = 0. 读取的时候用一个栈保存之前的结点,可以得到一颗二叉树,标记出现'X'的路径,先把没有出现'X'的子树算完,由于读取建树的时候 ...

  6. zzuoj--10399--Turing equation(模拟)

    Turing equation Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 152  Solved: 85 [Submit][Status][Web ...

  7. [CSP-S模拟测试]:Equation(数学+树状数组)

    题目描述 有一棵$n$个点的以$1$为根的树,以及$n$个整数变量$x_i$.树上$i$的父亲是$f_i$,每条边$(i,f_i)$有一个权值$w_i$,表示一个方程$x_i+x_{f_i}=w_i$ ...

  8. csp-s模拟测试56Merchant, Equation,Rectangle题解

    题面:https://www.cnblogs.com/Juve/articles/11619002.html merchant: 二分答案,贪心选前m大的 但是用sort复杂度不优,会T掉 我们只是找 ...

  9. csp-s模拟测试56(10.2)Merchant「二分」·Equation「树状数组」

    又死了......T1 Merchant 因为每个集合都可以写成一次函数的形式,所以假设是单调升的函数,那么随着t越大就越佳 而单调减的函数,随着t的增大结果越小,所以不是单调的??? 但是我们的单调 ...

随机推荐

  1. sorted()与sort()函数

    1 sorted可以对series,ndarry,list类型进行排序 默认会从小到大进行排序 arr1 = np.array([1,2,3,4,44,3243,43,8678]) print(sor ...

  2. usb接口类型 简单分类辨识

    usb接口类型 简单分类辨识 - [相似百科] 庆欣 0.0 4 人赞同了该文章 1. 先放图,随着越来越多的接触智能设备,会遇到各种各样的usb接口,对于很多人来说,接口类型只有:usb接口,安卓接 ...

  3. if you don't go after what you want, you'll never have it

    conquest.n. 征服 quantitative: adj. 数量的 cellar: n. 地窖 roast. v. 烧烤 allowance. n. 津贴 drainage. n. 排水 ma ...

  4. JS 数组的常用方法归纳之不改变原数组和其他

    不改变原数组的方法 concat() 连接两个或多个数组,不改变现有数组,返回新数组,添加的是数组中的元素 join(",") 把数组中的所有元素放入一个字符串,通过‘,’分隔符进 ...

  5. Windows + Ubuntu 16.04 双系统安装详细教程(转)

    转载自:http://www.cnblogs.com/Duane/p/6776302.html 前言:本篇文章是对之前文章的更新,更新的主内容是把原来用手机拍摄的图片换成了虚拟机的截图,以及对磁盘划分 ...

  6. SpringMvc参数绑定出现乱码解决方法

    在SpringMvc参数绑定过程中出现乱码的解决方法 1.post参数乱码的解决方法 在web.xml中添加过滤器 <!-- 过滤器 处理post乱码 --> <filter> ...

  7. CentOS7 修复boot目录

    这里为了达到实验目的,首先删除boot目录下所有内容 重启后发现系统进不去了,这正是我们想要的 进入系统救援模式,以重新引导系统 进入救援模式后,输入以下命令进行修复boot目录 重启后,能正常引导系 ...

  8. 哪吒票房超复联4,100行python代码抓取豆瓣短评,看看网友怎么说

    <哪吒之魔童降世>这部国产动画巅峰之作,上映快一个月时间,票房口碑双丰收. 迄今已有超一亿人次观看,票房达到42.39亿元,超过复联4,跻身中国票房纪录第三名,仅次于<战狼2> ...

  9. 【接口工具】mac环境下使用Charles抓包Https请求

    Charles支持针对Https包解析.具体安装导航请参考“[接口工具]接口抓包工具之Charles” 操作流程 电脑安装证书: Help-SSL Proxying-Install Charles R ...

  10. asp.net 获取表单中控件的值

    原文:https://blog.csdn.net/happymagic/article/details/8480235   C# 后台获取前台 input 文本框值.(都是以控件的Name来获取) s ...