D - D

CodeForces - 743A

Vladik is a competitive programmer. This year he is going to win the International Olympiad in Informatics. But it is not as easy as it sounds: the question Vladik face now is to find the cheapest way to get to the olympiad.

Vladik knows n airports. All the airports are located on a straight line. Each airport has unique id from 1 to n, Vladik's house is situated next to the airport with id a, and the place of the olympiad is situated next to the airport with id b. It is possible that Vladik's house and the place of the olympiad are located near the same airport.

To get to the olympiad, Vladik can fly between any pair of airports any number of times, but he has to start his route at the airport a and finish it at the airport b.

Each airport belongs to one of two companies. The cost of flight from the airport i to the airport j is zero if both airports belong to the same company, and |i - j| if they belong to different companies.

Print the minimum cost Vladik has to pay to get to the olympiad.

Input

The first line contains three integers na, and b (1 ≤ n ≤ 105, 1 ≤ a, b ≤ n) — the number of airports, the id of the airport from which Vladik starts his route and the id of the airport which he has to reach.

The second line contains a string with length n, which consists only of characters 0 and 1. If the i-th character in this string is 0, then i-th airport belongs to first company, otherwise it belongs to the second.

Output

Print single integer — the minimum cost Vladik has to pay to get to the olympiad.

Examples

Input
4 1 4
1010
Output
1
Input
5 5 2
10110
Output
0

Note

In the first example Vladik can fly to the airport 2 at first and pay |1 - 2| = 1 (because the airports belong to different companies), and then fly from the airport 2 to the airport 4for free (because the airports belong to the same company). So the cost of the whole flight is equal to 1. It's impossible to get to the olympiad for free, so the answer is equal to 1.

In the second example Vladik can fly directly from the airport 5 to the airport 2, because they belong to the same company.

题意:Vladik是一位有竞争力的程序员。今年,他将赢得国际信息学奥林匹克奖。但这并不像听起来那么容易:弗拉迪克现在面临的问题是寻找最廉价的到达奥林匹克运动会的方式。Vladik知道n个机场。所有的机场都位于一条直线上。每个机场的ID从1到n是唯一的,Vladik的房子位于ID为a的机场旁边,奥林匹克公园的位置位于ID为b的机场旁边。弗拉迪克的房子和奥林匹克奥林匹克的所在地可能位于同一机场附近。为了到达奥运会,弗拉迪克可以在任何一对机场之间任意飞行多次,但是他必须在机场a处开始其航线并在机场b处结束。每个机场属于两个公司之一。如果两个机场属于同一公司,则从机场i到机场j的飞行成本为零,如果属于不同的公司,则成本为| i-j |。

输入:第一行包含三个整数n,a和b(1≤n≤105,1≤a,b≤n)-机场数量,弗拉迪克开始其航线的机场ID和机场ID他必须达到的目标。第二行包含一个长度为n的字符串,该字符串仅包含字符0和1。如果该字符串中的第i个字符为0,则第i个机场属于第一家公司,否则属于第二家公司。

输出:打印单个整数-弗拉迪克(Vladik)参加奥林匹克运动会必须支付的最低费用。

题解:可以看出结果不是1就是0,当a==b时结果为0,不同时为1

#include<bits/stdc++.h>
using namespace std;
int main()
{
int n,a,b;
cin>>n>>a>>b;
string s;
for(int i=1;i<=n;i++)cin>>s[i];
if(s[a]==s[b])cout<<"0"<<endl;
else cout<<"1"<<endl;
}

E - E

CodeForces - 743B

/*/******/

题意:Chloe和Vladik一样,是个很有竞争力的程序员。和弗拉迪克一样,她没有遇到任何困难,但她对奥运会上提出的任务感到困惑。让我们考虑以下生成整数序列的算法。一开始我们有一个由一个等于1的元素组成的序列。然后执行(n - 1)步。在每一步中,我们取上一步得到的序列,把它附加到它自身的末尾,并在中间插入我们以前没有用过的最小正整数。例如,第一步后得到序列[1,2,1],第二步后得到序列[1,2,1,3,1,2,1]。任务是在得到的序列中找到索引为k的元素的值(元素从1开始编号),即经过(n - 1)步。请帮助Chloe解决这个问题!输入仅一行包含两个整数n和k (1<= n<= 50, 1<= k<= 2n - 1),输出打印单个整数,即得到序列中第k个位置的整数。

题解:

第几串       数组         中间的数             中间数的位置

1                 1                     1                               1

2               121                   2                               2

3            1213121              3                               4

n               .........                n                              2^(n-1)

先用数组将中间数的位置记录下来,因为中间数的后面都是与前面重复的数,所以可以只将有效长度设为2^(n-1),因为第几串的值就是中间数的值,所以当k=s[n]时直接输出n值,当k>s[n]时,k-=s[n],n--;直至k=s[n],输出此时的n值

#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
cin>>n;
long long k,i,j;
scanf("%lld",&k);
long long s[10000]={0};
for(i=1;i<=51;i++)//记下每步后的中间数的位置
{
if(i==1)s[i]=1;
else s[i]=pow(2,i-1);
}
while(k!=s[n])
{
if(k>s[n])
{
k=k-s[n];
}
n--;
}
cout<<n<<endl;
}

F - F

CodeForces - 743C

题意:弗拉迪克(Vladik)和克洛伊(Chloe)决定确定他们中谁在数学上更好。弗拉迪克声称,对于任何正整数n,他都可以将分数 表示为形式上为三个不同的正分数之和。帮助Vladik,即对于给定的n找到三个不同的正整数x,y和z,使 。因为如果数字很大,Chloe无法检查Vladik的答案,他要求您打印不超过10^9的数字。如果没有这样的答案,请打印-1。输入单行包含单个整数n(1≤n≤104)。输出如果存在答案,则打印3个不同的数字x,y和z(1≤x,y,z≤109,x≠y,x≠z,y≠z)。否则打印-1。如果有多个答案,请打印其中的任何一个。示例输入3输出2 7 42输入7输出7 8 56

题解:

n       分数           x   y   z

1       2/1               无

2        2/2            2    3    6

3         2/3           3   4    12

4         2/4            4  5     20

n          2/n            n   n+1   n*(n+1)

通过举例可以得到,n=1时结果为-1,其余情况下可以另结果为n  n+1   n*(n+1)

#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
scanf("%d",&n);
long long sum=0,num=0,h;
if(n==1)cout<<"-1"<<endl;
else
{
cout<<n<<" "<<n+1<<" "<<n*(n+1)<<endl;
}
}

2020.10.30--vj个人赛补题的更多相关文章

  1. 2020.10.17-pta天梯练习赛补题

    7-5敲笨钟 微博上有个自称"大笨钟V"的家伙,每天敲钟催促码农们爱惜身体早点睡觉.为了增加敲钟的趣味性,还会糟改几句古诗词.其糟改的方法为:去网上搜寻压"ong&quo ...

  2. 2020.10.16--vj个人赛补题

    D - Drinks Choosing Old timers of Summer Informatics School can remember previous camps in which eac ...

  3. 2020.10.9--vj个人赛补题

    B - A Tide of Riverscape 题意:给出一组字符串,由'0','1',' . '组成,' . '可以换成 0或1,判断第 i  个和第 i+p 个字符是否可以不相等,如果可以则输出 ...

  4. 2020.10.23-vj个人赛补题

    B - B Polycarp loves lowercase letters and dislikes uppercase ones. Once he got a string s consistin ...

  5. QFNU-ACM 2020.04.05个人赛补题

    A.CodeForces-124A (简单数学题) #include<cstdio> #include<algorithm> #include<iostream> ...

  6. 2020.12.3--vj个人赛补题

    A Vasya studies music.He has learned lots of interesting stuff. For example, he knows that there are ...

  7. 2020.12.20-Codeforces Round #105补题

    B - Escape The princess is going to escape the dragon's cave, and she needs to plan it carefully. Th ...

  8. 牛客 2020.10.20 TG 前两题

    T1 GCD 数学水题... 对于每个数,如果这个数有两个及以上的质因数的话,它所有除 \(1\) 之外的因数求 \(GCD\) 的值一定为 \(1\).那么判断是否是质数或质数的次方即可(质数除 \ ...

  9. 2020.11.14-pta天梯练习赛补题

    7-7 矩阵A乘以B 给定两个矩阵A和B,要求你计算它们的乘积矩阵AB.需要注意的是,只有规模匹配的矩阵才可以相乘.即若A有R​a​​行.C​a​​列,B有R​b​​行.C​b​​列,则只有C​a​​ ...

随机推荐

  1. 阿里云服务器部署mongodb

    在阿里云上买了个服务器,部署mongodb遇到一些坑,解决办法也是从网上搜集而来,把零零碎碎的整理记录一下. 服务器是:Alibaba Cloud Linux 下载安装 mongodb官网下载实在是太 ...

  2. java IO操作,看完你应该就清晰了。

    前言: java中IO里的一些知识对于一个java新手来说,是比较难理解的.因为里面存在一些很绕的概念,比如: 1.到底是读入写出,还是读出写入: 2.我要将一个文件的内容拷贝到另一个文件是先用Inp ...

  3. MySQL——InnoDB事务

    事务:全部成功 或 全部失败! ------------------------------------------------------------------------------------ ...

  4. Linux查看英伟达GPU信息

    命令: nvidia-smi 结果:

  5. QT 4.7.3 交叉编译环境搭建

    测试平台 宿主机平台:Ubuntu 12.04.4 LTS 目标机:Easy-ARM IMX283 目标机内核:Linux 2.6.35.3 交叉编译器:arm-linux-gcc 4.4.4 tsl ...

  6. Linux - yum 安装软件时被 PackageKit 锁定

    问题描述 yum 安装软件的时候报错 sudo yum install netease-cloud-music 已加载插件:fastestmirror, langpacks /var/run/yum. ...

  7. DHCP 协议及其交互过程

    1. DHCP用途简介: DHCP服务应用于大型局域网络中,使网络中的主机自动获取IP地址,网关,DNS服务器等信息,能够提升IP地址的利用率.一般情况下,我们的家用.公司.公共场合使用的路由器都具有 ...

  8. Winform EF CodeFist方式连接数据库

    直接生成ado.net 实体数据模型挺方便的,但只有一步步的手写代码才能更好的理解EF,在学习asp.net core过程中手写代码已经明白了怎么回事,但实现过程有些麻烦不知道如何记录,但Winfor ...

  9. Centos下Yum安装PHP7.0

    默认的版本太低了,手动安装有一些麻烦,想采用Yum安装的可以使用下面的方案: 1.检查当前安装的PHP包 yum list installed | grep php 如果有安装的PHP包,先删除他们 ...

  10. 浅谈VMware的NAT模式

    什么是NAT模式?理论化的措辞我就不说了,我将结合本人平时的经验来简单的说明一下NAT模式,以及配置NAT模式时遇到的问题. 大家都知道,我们的电脑要想联网,需要与交换机连接,假设交换机的网关为192 ...