7日共14题,因为3.14两题相同,所以实际总共13题

13道题分为难易两部分,没有按照时间顺序排列题目

A.易:

1.覆盖数字的数量

题意:

给出一段从A - B的区间S(A,B为整数)

这段区间内的整数可以随便使用任意次

再给出一段从X - Y的区间T

问用区间S中的整数做加法

可以覆盖区间T中多少个不同的整数

1<= A, B, X, Y <= 1e18

解法:

没有什么想法,我们观察样例

A = 8 B = 10 X = 3 Y = 20

由区间S凑成的整数为

8 9 10

16 17 18 19 20

我们继续列举发现继续凑成的整数为

24 25 26 27 28 29 30

32 33 34 35 36 37 38 39 40

可以发现会凑成许多段连续区间

每段区间的长度呈等差数列

并且如果A != B无限枚举下去最后一定会存在N

当Z >= N时,是一定可以凑出Z的

样例中的 N 即为40

我们继续思考可以发现 N 是满足下面条件的最小的数

N / A = N / B + 1

反映到上面列举的区间,即第4段中的40同时出现在了第5段中

那么必然有第5段中的某个数Z也出现在了第6段中 ......

所以后面所有Z >= 40都是能够被凑出来的

于是直接二分找出N,再算一下等差数列求和即可

 #include <cstdio>

 typedef long long ll;

 int Case;

 ll l, r, a, b, d, ans;

 ll max(ll x, ll y) {
return x > y ? x : y;
} ll calc(ll x) {
ll L = , R = 1e18, mid, N, res = ;
while(L <= R) {
mid = (L + R) >> ;
if(mid / a > mid / b) N = mid, R = mid - ;
else L = mid + ;
}
if(x >= N) res += x - N, x = N;
res += ((x / b + ) * d + ) * (x / b) / + max(0ll, x - (x / b + ) * a);
return res;
} int main() {
scanf("%d", &Case);
while(Case --) {
scanf("%lld %lld %lld %lld", &a, &b, &l, &r);
d = b - a, printf("%lld\n", calc(r) - calc(l - ));
}
return ;
}

2.Lucky Permutation Triple

题意:

0到(n-1)这n个数进行全排列

请找出三个全排列a、b、c

使得“a与b的对应元素的和”与“c的对应元素”对模n同余

无解输出-1

解法:

纯靠手感or脑洞

若n为奇数,则2, 4, 6, ..., 2n

在膜n意义下为2, 4, ..., n - 1, 1, 3, ... n - 2, 0

这样就直接凑出了0 - (n - 1)

若n为偶数,注意到题意

设Sa, Sb, Sc为abc三个排列的元素之和

此时应满足 (Sa + Sb) % n  = Sc % n

然而Sa = Sb = Sc = (n - 1) * n / 2

此时等式左侧为0, 右侧要想为0, 必须使n - 1为偶数

因为n为偶,所以n - 1为奇数,右侧不可能为0

所以此时无解输出 -1

 #include <cstdio>

 int n;

 int main() {
scanf("%d", &n);
if(n & ) {
for(int i = ;i < n;i ++)
printf("%d ", i);
printf("\n");
for(int i = ;i < n;i ++)
printf("%d ", i);
printf("\n");
for(int i = ;i < n;i ++)
printf("%d ", * i % n);
}
else puts("-1");
return ;
}

everyday two problems / 3.11 - 3.17的更多相关文章

  1. 2016年11月17日 星期四 --出埃及记 Exodus 20:8

    2016年11月17日 星期四 --出埃及记 Exodus 20:8 "Remember the Sabbath day by keeping it holy.当记念安息日,守为圣日.

  2. 2014年11月17~11月18日,杨学明老师《企业IT需求收集和实施》内训在湖南长沙某酒店成功举办!

    2014年11月17至18日,受湖南某软件企业的邀请,杨学明老师<企业IT需求收集和实施>内训在某长沙某五星级酒店成功举办!来自全国各地的IT高管和企业负责人参加了此次培训.杨学明老师分别 ...

  3. 基数排序的可复用实现(C++11/14/17/20)

    基数排序,是对整数类型的一种排序方法,有MSD (most significant digit)和LSD (least significant digit)两种.MSD将每个数按照高位分为若干个桶(按 ...

  4. PSP(5.11——5.17)以及周记录

    1.PSP 5.11 14:30 20:00 130 200 Cordova A Y min 5.12 9:00 14:00 100 200 Cordova A Y min 5.13 13:30 15 ...

  5. 云计算之路-阿里云上:2014年6月11日17点遇到的CPU 100%状况

    今天下午17:00-17:05之间,在请求量没有明显变化的情况下,SLB中的1台云服务器的CPU突然串到100%(当时SLB中一共有3台云服务器),见下图: 造成的直接后果是请求执行时间变得超长,最长 ...

  6. Support For C++11/14/17 Features (Modern C++)

    Visual Studio编译器对 C++11 特性的支持 具体参考网址:https://msdn.microsoft.com/en-us/library/hh567368.aspx 截至目前为止,V ...

  7. 2016年11月17日--SQL主、外键,子查询

    主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...

  8. 2014年11月17号------html起始

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. 2017年5月11日17:43:06 rabbitmq 消费者队列

    从昨天开始发现个问题,一个接口在本地调用时大部分正常,一旦在生成者打一个断点调试,并且在promotion也打断点的时候会出现没有返回channel的异常,然后消费者就再也消费不了了 16:57:45 ...

随机推荐

  1. 【HAOI 2008】 糖果传递

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1045 [算法] 环形均分纸牌问题 [代码] #include<bits/std ...

  2. PCB 规则引擎之JSON对象查看器

    在PCB规则引擎开发中,JavaScript V8引擎是处理业务逻辑的, 当然业务逻辑需要数据支撑才行,  即需有将数据推进入到V8引擎.目前这边数据传输到JavaScript V8引擎以C# Mod ...

  3. php phppowerpoint

    今天早上从订阅的 Zend DevZone 看到篇很有意思的文章. Creating PowerPoint 2007 files using PHP. 试了一下. 果然很又意思, 分享给大家吧. 程序 ...

  4. go 成长路上的坑(1)

    一.先来看一段代码 package main import "fmt" type X struct{} func (x *X) test(){ println("h1&q ...

  5. JavaScript正则表达式(一)-常用方法

    公司之前有个胖女孩说你竟然会正则? 其实正则没那么难:今天我们说说他常用的几个API. 在讲方法之前, 我们先对正则表达式做一个基本的了解: 1.正则表达式定义使用单个字符串来描述.匹配一系列符合某个 ...

  6. 详细介绍idea实现javaweb项目登入注册(华东交通大学教务处信息管理系统)、模糊查询

    详细介绍idea实现javaweb项目登入注册(华东交通大学教务处信息管理系统).模糊查询 1,创建数据库,我的用户名:root 密码:root,数据库名称:lianwei,表名:login 2,效果 ...

  7. vuejs {{}},v-text 和 v-html的区别

    <div id="app"> <p>{{message}}</p> <!-- 输出:<span>通过双括号绑定</spa ...

  8. Centos7 时间不正确修复

    查看系统支持的时区列表 timedatectl list-timezones 使用 date -R 查看时区是否正确 date -R 修改时区 timedatectl set-timezone Asi ...

  9. 动态规划DP入门

    百度百科↓ 动态规划(dynamic programming)是运筹学的一个分支,是求解决策过程(decision process)最优化的数学方法.20世纪50年代初美国数学家R.E.Bellman ...

  10. 为什么使用HttpServlet?http协议特点、servlet

    因为只有HttpServlet是基于http协议,实现Servlet接口,而http协议是短连接协议,能够实现客户端访问服务端后,数据交互后 连接自动断开.同时http协议基于tcp.ip协议,封装了 ...