http://acm.hdu.edu.cn/showproblem.php?pid=6627

题意:解绝对值方程并统计解的个数。

解法:签到题,直接模拟小学数学学的零点分段法即可。(数据多直接cin,cout会T,还以为是算法有问题...

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 1e5+;
ll s1[maxn],s2[maxn]; struct node{
ll a,b;
double s;
}g[maxn]; bool cmp(node p,node q){
return p.s>q.s;
} struct note{
ll x,y;
double s;
}v[maxn]; bool cmp1(note p1,note q1){
return p1.s<q1.s;
} map<double,int> ma; int main(){
ios::sync_with_stdio();
cin.tie();
cout.tie();
int t;
cin>>t;
ll n,c;
while(t--){
int cnt = ;
ma.clear();
cin>>n>>c;
for(ll i=;i<=n;i++){
cin>>g[i].a>>g[i].b;
g[i].s = -1.0*g[i].b/g[i].a;
}
sort(g+,g+n+,cmp);
s1[] = ; s2[] = ;
for(ll i=;i<=n;i++){
s1[i] = s1[i-]+g[i].a;
s2[i] = s2[i-]+g[i].b;
}
int flag = ;
for(ll i=;i<=n;i++){
ll a1 = s1[n]-*s1[i];
ll a2 = s2[n]-*s2[i];
ll s = c-a2; //a1*x=s
if(a1==&&s==){
flag = ;
break;
}
else if(a1==){
continue;
}
else {
ll num1 = abs(s);
ll num2 = abs(a1);
ll gcd = __gcd(num1,num2);
double ss = (double)s/a1;
if((i==n||ss>g[i+].s)&&(i==||ss<=g[i].s)){
if(ma[ss]==){
ma[ss]++;
v[cnt].x = s/gcd;
v[cnt].y = a1/gcd;
v[cnt].s = ss;
cnt++;
}
}
}
}
if(flag==){
cout<<-<<endl;
}
else{
cout<<cnt;
sort(v,v+cnt,cmp1);
for(ll i=;i<cnt;i++){
if(v[i].x*v[i].y>){
cout<<' '<<abs(v[i].x)<<'/'<<abs(v[i].y);
}
else if(v[i].x*v[i].y==){
cout<<' '<<"0/1";
}
else {
cout<<" -"<<abs(v[i].x)<<'/'<<abs(v[i].y);
}
}
cout<<endl;
}
}
return ;
}

杭电多校 hdu6627 equation的更多相关文章

  1. 可持久化线段树的学习(区间第k大和查询历史版本的数据)(杭电多校赛第二场1011)

    以前我们学习了线段树可以知道,线段树的每一个节点都储存的是一段区间,所以线段树可以做简单的区间查询,更改等简单的操作. 而后面再做有些题目,就可能会碰到一种回退的操作.这里的回退是指回到未做各种操作之 ...

  2. 2018 Multi-University Training Contest 1 杭电多校第一场

    抱着可能杭电的多校1比牛客的多校1更恐怖的想法 看到三道签到题 幸福的都快哭出来了好吗 1001  Maximum Multiple(hdoj 6298) 链接:http://acm.hdu.edu. ...

  3. 2018 Multi-University Training Contest 9 杭电多校第九场 (有坑待补)

    咕咕咕了太久  多校博客直接从第三场跳到了第九场orz 见谅见谅(会补的!) 明明最后看下来是dp场 但是硬生生被我们做成了组合数专场…… 听说jls把我们用组合数做的题都用dp来了遍 这里只放了用组 ...

  4. 2018 Multi-University Training Contest 2 杭电多校第二场

    开始逐渐习惯被多校虐orz  菜是原罪 1004  Game    (hdoj 6312) 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6312 虽然披着 ...

  5. 2019杭电多校&CCPC网络赛&大一总结

    多校结束了, 网络赛结束了.发现自己还是太菜了,多校基本就是爆零和签到徘徊,第一次打这种高强度的比赛, 全英文,知识点又很广,充分暴露了自己菜的事实,发现数学还是很重要的.还是要多刷题,少玩游戏. 网 ...

  6. HDU 4941 Magical Forest(map映射+二分查找)杭电多校训练赛第七场1007

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4941 解题报告:给你一个n*m的矩阵,矩阵的一些方格中有水果,每个水果有一个能量值,现在有三种操作,第 ...

  7. HDU 4902 Nice boat 2014杭电多校训练赛第四场F题(线段树区间更新)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4902 解题报告:输入一个序列,然后有q次操作,操作有两种,第一种是把区间 (l,r) 变成x,第二种是 ...

  8. HDU 5831 Rikka with Parenthesis II (贪心) -2016杭电多校联合第8场

    题目:传送门. 题意:T组数据,每组给定一个长度n,随后给定一个长度为n的字符串,字符串只包含'('或')',随后交换其中两个位置,必须交换一次也只能交换一次,问能否构成一个合法的括号匹配,就是()( ...

  9. HDU 5821 Ball (贪心排序) -2016杭电多校联合第8场

    题目:传送门. 题意:T组数据,每组给定一个n一个m,在给定两个长度为n的数组a和b,再给定m次操作,每次给定l和r,每次可以把[l,r]的数进行任意调换位置,问能否在转换后使得a数组变成b数组. 题 ...

随机推荐

  1. vue教程二 vue组件(1)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <script ...

  2. 【iOS】containsString iOS7 报错

    前几天发现了这个问题,原来是因为 containsString 只支持 iOS8.0 以后的系统,不支持 7... 有些地方可以用其他方法替代,如下: NSString *urlString = [[ ...

  3. ansible-service

    #service#查询服务状态 ansible server01 -m service -a "name=httpd state=started" #停止服务 ansible se ...

  4. 改MySQL的编码方式,解决jdbc MySQL中文乱码问题

    进MySQL安装目录,打开my.ini 这两个地方改成gbk 重启服务

  5. Pyenv虚拟环境的创建(虚拟机)

    创建pyenv虚拟环境 sudo yum install openssl* 安装其所需要的库文件 git clone https://github.com/yyuu/pyenv.git ~/.pyen ...

  6. 【数据结构学习】关于HashMap的那些事儿

    涉及数据结构 红黑树 链表 哈希 从CRUD说起 预热知识: DEFAULT_INITIAL_CAPACITY = 1 << 4, HashMap默认容量为16(n << m意 ...

  7. JAVA基础知识(九)Java 异常

    Throwable是Error和Exception的基类 Exception(异常) :是程序本身可以处理的异常. Error(错误): 是程序无法处理的错误.这些错误表示故障发生于虚拟机自身.或者发 ...

  8. Docker 核心技术

    docker是什么?为什么会出现? 容器虚拟化技术:轻量级的虚拟机(但不是虚拟机) 开发:提交代码 ——> 运维:部署 在这中间,因为环境和配置,出现问题 ——> 把代码/配置/系统/数据 ...

  9. vs 中本地 git 的基本使用

    用 svn  有个毛病就是只有在改好了之后,才能提交.当周期比较长的时候,连自己都不知道自己改了什么东西,或者意外断电的时候,vs 中已保持的项目都有可能被 vs 去掉. 这个时候,使用 git 创建 ...

  10. Unity进阶之ET网络游戏开发框架 08-深入登录成功消息

    版权申明: 本文原创首发于以下网站: 博客园『优梦创客』的空间:https://www.cnblogs.com/raymondking123 优梦创客的官方博客:https://91make.top ...