杭电多校 hdu6627 equation
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的更多相关文章
- 可持久化线段树的学习(区间第k大和查询历史版本的数据)(杭电多校赛第二场1011)
以前我们学习了线段树可以知道,线段树的每一个节点都储存的是一段区间,所以线段树可以做简单的区间查询,更改等简单的操作. 而后面再做有些题目,就可能会碰到一种回退的操作.这里的回退是指回到未做各种操作之 ...
- 2018 Multi-University Training Contest 1 杭电多校第一场
抱着可能杭电的多校1比牛客的多校1更恐怖的想法 看到三道签到题 幸福的都快哭出来了好吗 1001 Maximum Multiple(hdoj 6298) 链接:http://acm.hdu.edu. ...
- 2018 Multi-University Training Contest 9 杭电多校第九场 (有坑待补)
咕咕咕了太久 多校博客直接从第三场跳到了第九场orz 见谅见谅(会补的!) 明明最后看下来是dp场 但是硬生生被我们做成了组合数专场…… 听说jls把我们用组合数做的题都用dp来了遍 这里只放了用组 ...
- 2018 Multi-University Training Contest 2 杭电多校第二场
开始逐渐习惯被多校虐orz 菜是原罪 1004 Game (hdoj 6312) 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6312 虽然披着 ...
- 2019杭电多校&CCPC网络赛&大一总结
多校结束了, 网络赛结束了.发现自己还是太菜了,多校基本就是爆零和签到徘徊,第一次打这种高强度的比赛, 全英文,知识点又很广,充分暴露了自己菜的事实,发现数学还是很重要的.还是要多刷题,少玩游戏. 网 ...
- HDU 4941 Magical Forest(map映射+二分查找)杭电多校训练赛第七场1007
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4941 解题报告:给你一个n*m的矩阵,矩阵的一些方格中有水果,每个水果有一个能量值,现在有三种操作,第 ...
- HDU 4902 Nice boat 2014杭电多校训练赛第四场F题(线段树区间更新)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4902 解题报告:输入一个序列,然后有q次操作,操作有两种,第一种是把区间 (l,r) 变成x,第二种是 ...
- HDU 5831 Rikka with Parenthesis II (贪心) -2016杭电多校联合第8场
题目:传送门. 题意:T组数据,每组给定一个长度n,随后给定一个长度为n的字符串,字符串只包含'('或')',随后交换其中两个位置,必须交换一次也只能交换一次,问能否构成一个合法的括号匹配,就是()( ...
- HDU 5821 Ball (贪心排序) -2016杭电多校联合第8场
题目:传送门. 题意:T组数据,每组给定一个n一个m,在给定两个长度为n的数组a和b,再给定m次操作,每次给定l和r,每次可以把[l,r]的数进行任意调换位置,问能否在转换后使得a数组变成b数组. 题 ...
随机推荐
- 【iOS】XIB 调整视图大小
使用 XIB 创建视图的时候,拖拽 UIView 到画布时,大小是不可调整的,如何自由调整大小呢? 选中 UIView 并打开属性面板,将 Simulated Metrics 中的 Size 设为 F ...
- 【iOS】iOS viewDidLoad 方法名问题
这两天在调试一个项目,跳转到一个页面的时候总是不显示标题栏(当然也没有标题栏的返回按钮),搞了好久,今天总算找到了问题:之前的开发人员竟然把 viewDidLoad 这个基本的方法名写成了 views ...
- Core CLR Host 源码简单分析
在定制 CLR Host的时候,可以通过调用如下代码,来获取当前需要被宿主的程序调用入口: hr = Host->CreateDelegate( domainId, L"Main,Ve ...
- Linux 常用命令及使用方法
1. type :查询命令 是否属于shell解释器 2. help : 帮助命令3. man : 为所有用户提供在线帮助4. ls : 列表显示目录内的文件及目录 -l 以长格 ...
- H3C模拟器实验之网络地址转换
网络拓扑图 NOTE:各个设备的基本配置在拓扑图上已经标明(需要注意的是RTB的出接口也需要配置IP,但是使用ping -a 10.1.1.1 202.117.144.1 ping不通,这点不是很理解 ...
- leetcode并发题目解题报告JAVA版
一.Print in Order Suppose we have a class: public class Foo { public void first() { print("first ...
- 把Python项目打包成exe文件
我们很多时候,写好的程序需要打包成.exe文件才可以发给客户,那么今天我就来谈一谈,如何将一个写好的Python程序打包成exe文件! 首先,我们我们使用到的工具是python 3.7 和 Pyins ...
- Netty源码分析--内存模型(上)(十一)
前两节我们分别看了FastThreadLocal和ThreadLocal的源码分析,并且在第八节的时候讲到了处理一个客户端的接入请求,一个客户端是接入进来的,是怎么注册到多路复用器上的.那么这一节我们 ...
- javaScript基础-03 javascript语句
一. 声明语句 var和function都是声明语句.声明或定义变量或函数. var 声明一个或者多个变量.语法如下: var a ; var b = 1; var c, d; var e = 3; ...
- 扩展GroupBox控件
1.GroupBox的边框颜色可以自行设置: 2.GroupBox可以设置边框的为圆角: 3.设置GroupBox标题在控件中的位置. 4.设置GroupBox标题的字体和颜色. 具体实现步骤Pane ...