传送门

题意

t组样例

n个学生,

x最多交换次数

a交换的第一个位置

b交换的第二个位置

最多是交换n-1次,不懂的话可以找个数列自己模拟一下;

然后其他的就是abs(a-b)+x;两个位置之间的距离加上次数(即变化的距离)

#include <bits/stdc++.h>

#define int long long
using namespace std;
const int MAXN = 1e6 + 10;

signed main(){
    //freopen("in", "r", stdin);
    ios::sync_with_stdio(false);
    cin.tie(0);
    int T;
    cin >> T;
    while (T--){
        int n, x, a, b;
        cin >> n >> x >> a >> b;
        int max = n - 1;
        int tmp = abs(a - b);
        cout << min(n - 1, tmp + x) << endl;
    }
    return 0;
}

传送门

题意

T组样例

每次给出x,y

1.x 是偶数,可以变成3/2 * x;

2.x > 1,可以执行x - 1

如果x 是偶数并且大于1,可以选择任何一个操作(我也搞不懂他为什么要这么说,x的范围大于1,又是偶数,那么x min不就是2嘛。。。。)

操作可以执行任意次,也可以不执行

x 1 2 3 4
y 1 1,2,3, 1,2,3 3,2,1,6,5,4,9,…

输出YES的情况

如果x是1的话,那么y只能是1

如果x是2的话,x可以执行操作1,2;

执行1,那么就是3,然后只能是执行2,变成2,

执行2,那么就是1

如果x是3,x可以执行2,变成2,那么同上,1,2,3

如果x是4的话,x可以执行操作1,2;

执行1,那么就是6,

然后再是执行1,变成9,执行2,变成8,执行1,变成12.。。。

执行2,那么就是3,然后执行2,变成2,然后执行2,变成1,

这一步的时候,其实都取到了,所以我们特判一下就可以了

#include <bits/stdc++.h>

#define int long long
using namespace std;
const int MAXN = 1e6 + 10;

signed main(){
    //freopen("in", "r", stdin);
    ios::sync_with_stdio(false);
    cin.tie(0);
    int T;
    cin >> T;
    while (T--){
        int a, b;
        cin >> a >> b;
        if (a == 1){
            if (a == b)
                cout << "YES" << endl;
            else
                cout << "NO" << endl;
        } else if (a == 2 || a == 3){
            if (b == 2 || b == 3 || b == 1)
                cout << "YES" << endl;
            else
                cout << "NO" << endl;
        } else
            cout << "YES" << endl;
    }
    return 0;
}

传送门

说一下这个题吧,让人爱恨不得,刚开始的时候,看了一眼。然后理解了能分成几个子集QAQ,至于为什么,看到了括号,然后就这样了



今晚和王队讨论的时候,说起了这个题,原来是求相同的两个数之间的最短的距离,数据范围2e5;

所以呢,写了写2333

#include <bits/stdc++.h>
#define int long long
using namespace std;
const int maxn = 2e5 + 10;
int vis[maxn], a[maxn];
int len;
signed main(){
    //freopen("in", "r", stdin);
    ios::sync_with_stdio(false);
    cin.tie(0);
    int T, n;
    cin >> T;
    while (T--){
        memset(vis,0,sizeof(vis));
        cin >> n;
        if (n == 1){
            cin >> a[1];
            cout << "-1" << endl;
        }
        else {
            len = 0x3f3f3f3f;
            for (int i = 1; i <= n; i++) {
                cin >> a[i];

                if (vis[a[i]])
                    len = min(len, i - vis[a[i]] + 1);
                vis[a[i]] = i;
            }
            if (len != 0x3f3f3f3f)//预防1 2 3 4 5这种情况
                cout << len << endl;
            else
                cout << "-1" << endl;
        }

    }
    return 0;
}

cf 76 div2的更多相关文章

  1. cf 442 div2 F. Ann and Books(莫队算法)

    cf 442 div2 F. Ann and Books(莫队算法) 题意: \(给出n和k,和a_i,sum_i表示前i个数的和,有q个查询[l,r]\) 每次查询区间\([l,r]内有多少对(i, ...

  2. CF#603 Div2

    差不多半年没打cf,还是一样的菜:不过也没什么,当时是激情,现在已是兴趣了,开心就好. A Sweet Problem 思维,公式推一下过了 B PIN Codes 队友字符串取余过了,结果今天早上一 ...

  3. CF R631 div2 1330 E Drazil Likes Heap

    LINK:Drazil Likes Heap 那天打CF的时候 开场A读不懂题 B码了30min才过(当时我怀疑B我写的过于繁琐了. C比B简单多了 随便yy了一个构造发现是对的.D也超级简单 dp了 ...

  4. CF#581 (div2)题解

    CF#581 题解 A BowWow and the Timetable 如果不是4幂次方直接看位数除以二向上取整,否则再减一 #include<iostream> #include< ...

  5. [CF#286 Div2 D]Mr. Kitayuta's Technology(结论题)

    题目:http://codeforces.com/contest/505/problem/D 题目大意:就是给你一个n个点的图,然后你要在图中加入尽量少的有向边,满足所有要求(x,y),即从x可以走到 ...

  6. CF 197 DIV2 Xenia and Bit Operations 线段树

    线段树!!1A 代码如下: #include<iostream> #include<cstdio> #define lson i<<1 #define rson i ...

  7. CF#345 div2 A\B\C题

    A题: 贪心水题,注意1,1这组数据,坑了不少人 #include <iostream> #include <cstring> using namespace std; int ...

  8. CF R303 div2 C. Woodcutters

    C. Woodcutters time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  9. CF 192 Div2

    A.Cakeminator 暴搞之,从没有草莓覆盖的行.列遍历 char map[30][30]; int vis[30][30]; int hang[30],lie[30]; int main() ...

随机推荐

  1. 题解【洛谷P2002】消息扩散

    题面 题解 \(Tarjan\)裸题. \(Tarjan\)缩点后统计入度为\(0\)的强连通分量个数,输出即可. 代码 #include <iostream> #include < ...

  2. 516,base64的原理及优缺点

    优点是可以加密,减少了http请求 缺点是需要消耗cpu进行编解码 适用于小图片 base的体积约为原图的4/3

  3. Sliding Window POJ - 2823 单调队列模板题

    Sliding Window POJ - 2823 单调队列模板题 题意 给出一个数列 并且给出一个数m 问每个连续的m中的最小\最大值是多少,并输出 思路 使用单调队列来写,拿最小值来举例 要求区间 ...

  4. angular 读写电脑本地文件

    angular 读写本地电脑文件 angular将数据写进到电脑文件 在前端写一个按钮,然后点击按钮的时候在本地电脑保存一个text文件. 这时候我们需要用到一个angular的插件,叫做" ...

  5. 每天进步一点点------Allegro中Autosilk top, Silkscreen top 和Assembly top三个什么区别

    Autosilk top:最后出gerber的时候,自动生成的丝印层.会自动调整丝印位置,以及碰到阻焊开窗的地方,丝印会自动消失,避免露锡的地方涂上丝印(一般画丝印层的时候,焊盘上不会画上丝印,所以过 ...

  6. Java通过反射读取泛型

    1.在这里有必要先提一句关于javabean,建议有一个构造器,而不是必须要写的,这是一个良好的习惯. 这样做肯定是有好处的,如果你的一个类写了带参的构造方法,而没有写空的构造方法,那么,如有有一个类 ...

  7. 问题总结:mysql和javaweb工程连接的过程中容易产生的问题

    问题背景:自己在本机的mysql8瘫痪了,将Oracle中的数据迁移到mysql之后,配置好javaweb工程和虚拟机上的远程Mysql连接的文件之后:遇见了无法访问的问题 具体的配置: dataso ...

  8. Python 数据分析实战 | 用数据带你回顾乔丹的职业生涯

    乔丹是联盟上下公认的历史第一人,芝加哥公牛在他带领下几乎统治了上世纪 90 年代 NBA 整整 10 年,包括分别在 91-93 赛季和 96-98 赛季拿下的两次三连冠,要知道,NBA72 年历史上 ...

  9. mysql的数据库开放权限

    链接数据库之后运行下面的命令即可 grant all PRIVILEGES on *.* to %username%@'%' identified by '%password%'; 如给root链接数 ...

  10. TXT文件也能挂木马

    什么?TXT文件也能挂马?是的!TXT文件不仅有挂马的危险,而且有时候可能非常的危险!不过,严格说来,应该给这个所谓的"TXT"文件加个引号,因为它们是看起来是TXT文件,实则是隐 ...