2019 Multi-University Training Contest 5

http://acm.hdu.edu.cn/contests/contest_show.php?cid=852

1004. Equation

把所有绝对值的零点排个序,然后解方程就好了。

#include<bits/stdc++.h>
using namespace std; // #define int long long void read(int &x) {
x=0;int f=1;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-f;
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';x*=f;
} void print(int x) {
if(x<0) putchar('-'),x=-x;
if(!x) return ;print(x/10),putchar(x%10+48);
}
void write(int x) {if(!x) putchar('0');else print(x);putchar('\n');} #define lf long double #define pii pair<int,int >
#define vec vector<int > #define pb push_back
#define mp make_pair
#define fr first
#define sc second #define FOR(i,l,r) for(int i=l,i##_r=r;i<=i##_r;i++) const int maxn = 1e6+10;
const int inf = 1e9;
const lf eps = 1e-10;
const int mod = 1e9+7; struct data {int a,b;lf x;}a[maxn],sta[maxn];
int n,top; int cmp(data a,data b) {return a.x<b.x;} data make(int a,int b) {return (data){a,b,(lf)b/(lf)a};} void solve() {
int c;
read(n),read(c);int suma=0,sumb=c;
for(int i=1;i<=n;i++) read(a[i].a),read(a[i].b),a[i].x=-(lf)a[i].b/a[i].a,suma-=a[i].a,sumb+=a[i].b;
sort(a+1,a+n+1,cmp);top=0;
if((lf)sumb/suma<a[1].x-eps) sta[++top]=make(suma,sumb);
a[n+1].x=2e9;
for(int i=1;i<=n;i++) {
suma+=a[i].a*2,sumb-=a[i].b*2;lf x;
if(suma==0) {
if(sumb==0) return puts("-1"),void();
continue;
}else x=(lf)sumb/suma;
if(a[i].x<=x&&x<=a[i+1].x) sta[++top]=make(suma,sumb);
}sort(sta+1,sta+top+1,cmp);
int ans=0;
for(int i=1;i<=top;i++) {
int &a=sta[i].a,&b=sta[i].b,f=1;
if(a<0) f=-f,a=-a;if(b<0) f=-f,b=-b;
if(b==0) {a=1;if(!(a==sta[i-1].a&&b==sta[i-1].b)) ans++;continue;}
int t=__gcd(a,b);a/=t,b/=t;
if(f==-1) b=-b;if(!(a==sta[i-1].a&&b==sta[i-1].b)) ans++;
}printf("%d%c",ans,ans?' ':'\n');
for(int i=1;i<=top;i++)
if(!(sta[i].a==sta[i-1].a&&sta[i].b==sta[i-1].b)) {
int a=sta[i].a,b=sta[i].b;
if(b==0) {printf("0/1%c",(--ans)?' ':'\n');continue;}
printf("%d/%d%c",b,a,(--ans)?' ':'\n');
}
} signed main() {
int t;read(t);while(t--) solve();
return 0;
}

1007. Permutation 2

先考虑\(p_1=1,p_n=n\)怎么做,设\(f_n\)表示长度为\(n\)的方案数。

枚举最后几个数的放法,可以发现只有这么两种:

\(\cdots,n-1,n\)或者\(\cdots,n-3,n-1,n-2,n\),其他的要么不合法要么就可以归纳到这两种里面。

所以可以得到转移:\(f_n=f_{n-1}+f_{n-3}\)。

再考虑\(p_1=a,p_n=b\)怎么做,注意到\(1\sim a-1\)必然要遍历到,那么必然要先遍历这些,一开始的序列一定是形如:\(a,a-2,a-4\cdots 1,3 \cdots a-1,a+1\),后面同理。

所以可以看作是\(a+1\sim b-1\)随便填,其他的唯一确定。

中间的部分就是刚刚算出来的\(f\)。

#include<bits/stdc++.h>
using namespace std; void read(int &x) {
x=0;int f=1;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-f;
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';x*=f;
} void print(int x) {
if(x<0) putchar('-'),x=-x;
if(!x) return ;print(x/10),putchar(x%10+48);
}
void write(int x) {if(!x) putchar('0');else print(x);putchar('\n');} #define lf double #define pii pair<int,int >
#define vec vector<int > #define pb push_back
#define mp make_pair
#define fr first
#define sc second #define FOR(i,l,r) for(int i=l,i##_r=r;i<=i##_r;i++) const int maxn = 1e6+10;
const int inf = 1e9;
const lf eps = 1e-8;
const int mod = 998244353; int f[maxn]; void solve() {
int x,y,n,a,b;
read(n),read(x),read(y);
if(y-x==1&&x!=1&&y!=n) return puts("0"),void();
if(y-x<=2) return puts("1"),void();
if(x==1) a=1;else a=x+1;
if(y==n) b=n;else b=y-1;
write(f[b-a+1]);
} int main() {
f[1]=1,f[2]=1,f[3]=1;
for(int i=4;i<maxn;i++) f[i]=(f[i-1]+f[i-3])%mod;
// for(int i=1;i<=20;i++) printf("%d %d\n",i,f[i]);;
int t;read(t);while(t--) solve();
return 0;
}

HDU校赛 | 2019 Multi-University Training Contest 5的更多相关文章

  1. HDU校赛 | 2019 Multi-University Training Contest 6

    2019 Multi-University Training Contest 6 http://acm.hdu.edu.cn/contests/contest_show.php?cid=853 100 ...

  2. HDU校赛 | 2019 Multi-University Training Contest 4

    2019 Multi-University Training Contest 4 http://acm.hdu.edu.cn/contests/contest_show.php?cid=851 100 ...

  3. HDU校赛 | 2019 Multi-University Training Contest 3

    2019 Multi-University Training Contest 3 http://acm.hdu.edu.cn/contests/contest_show.php?cid=850 100 ...

  4. HDU校赛 | 2019 Multi-University Training Contest 2

    2019 Multi-University Training Contest 2 http://acm.hdu.edu.cn/contests/contest_show.php?cid=849 100 ...

  5. HDU校赛 | 2019 Multi-University Training Contest 1

    2019 Multi-University Training Contest 1 http://acm.hdu.edu.cn/contests/contest_show.php?cid=848 100 ...

  6. hdu 4930 Fighting the Landlords--2014 Multi-University Training Contest 6

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4930 Fighting the Landlords Time Limit: 2000/1000 MS ...

  7. HDU 6143 - Killer Names | 2017 Multi-University Training Contest 8

    /* HDU 6143 - Killer Names [ DP ] | 2017 Multi-University Training Contest 8 题意: m个字母组成两个长为n的序列,两序列中 ...

  8. HDU 6074 - Phone Call | 2017 Multi-University Training Contest 4

    看标程的代码这么短,看我的.... 难道是静态LCA模板太长了? /* HDU 6074 - Phone Call [ LCA,并查集 ] | 2017 Multi-University Traini ...

  9. HDU 6068 - Classic Quotation | 2017 Multi-University Training Contest 4

    /* HDU 6068 - Classic Quotation [ KMP,DP ] | 2017 Multi-University Training Contest 4 题意: 给出两个字符串 S[ ...

随机推荐

  1. Java中 / 和 %

    Java中 / 和 % 每天积累一些 Java 的知识点,补充自己的不足. 今天在刷面试题的碰到 % ,一下子还真想不起来这个运算符的作用,赶紧重温一下,这里我写了个小代码来体现 / 和 % 的区别. ...

  2. B端产品需求文档怎么写?

    B端,或者2B,一般指的是英文中的 to busniss,中文即面向企业的含义.与B端相对应的,是C端,或者2C,同样指的是英文中的 to customer,即面向消费者的意思.因此,人们平常所说的B ...

  3. django迁移脚本

    执行migrate报错的解决办法: 想知道migrate为什么报错,需要先了解migrate到底做了什么事情 migrate做了什么事情? 1.将相关的迁移脚本翻译成sql语句,然后在数据库中执行 2 ...

  4. wordpress中文目录出现“有点尴尬诶!该页无法显示"

    原因不详,可能是.htaccess.网上说删除后再更新固定链接会再生成,但是我没有.我又把原来的.htaccess上传后更改固定链接为“数字型”,测试后可以正常浏览. 然后又再更改为原来的“日期和名称 ...

  5. for each 语句

    for each 语句是java5新增,在遍历数组.集合的时候,for each拥有不错的性能. for each 虽然能遍历数组或者集合,但是只能用来遍历,无法在遍历的过程中对数组或者集合进行修改. ...

  6. ubuntu使用anaconda安装tensorflow

    https://blog.csdn.net/shiheyingzhe/article/details/80863422 https://blog.csdn.net/sheyanshangjiang/a ...

  7. 一个小问题 关于 com.mysql.jdbc.PacketTooBigException: Packet for query is too large

    这个错本身就是应为传输的数据大于mysql的max_allowed_packet参数默认值造成的: 之前遇到这个问题,一直是改max_allowed_packet的值 ,做项目遇到这个错误改了好几次, ...

  8. es6 中的模块导入与nodejs 中模块的导入的异同!

    我们知道es6 的模块导入导出是通过import 和 export 来实现,而nodejs的模块导入导出是通过require 和module.exports 来实现,那么它们有什么异同吗? 请看如下: ...

  9. Babel7 转码

    ES6 (ES2015)更新了很多新的js语法, 也添加了一些新的API, 但不是所有的浏览器对这些新特性都支持的很好, 通过babel可以高版本的js转成低版本的js (ES 5.1), 同时对于J ...

  10. python paramiko的使用介绍

    一: 使用paramiko #设置ssh连接的远程主机地址和端口t=paramiko.Transport((ip,port))#设置登录名和密码t.connect(username=username, ...