10.9wannafly模拟赛

反正即使抱着抽奖去的,做了两个签到题嘛。

题目描述
一只南美洲亚马孙河流域热带雨林中的蝴蝶,偶尔扇动几下翅膀,可
以在两周以后引起美国德克萨斯州的一场龙卷风。――蝴蝶效应
由于这个理论的存在,大多数人认为将未来的事物送回过去将会引发
严重的时间悖论,但事实上还存在另外一套理论。
自然会对这类不和谐的蝴蝶效应做出调整,具体地来说就是触发一些
小概率的恶性事件来抹杀穿越者来消除其对未来的影响。
虽然听上去很荒诞,但Alicebell决定去验证这一假说,她将按1 ∼ n的
顺序依次到访过去的n个时间点。
这n个时间点各有一个能源参数A𝑖,即到达这个时间点时,身上必须
保证有A𝑖单位的能量,那之后将会消耗掉一单位的能量。
Alicebell想知道依次到访这n个时间点,最初需要携带至少多少能量。
输入描述:
第一行,一个正整数n。
第二行,n个正整数A𝑖。
输出描述:
一行,一个正整数,最初需要携带能量下限。
示例1
输入

5
1 2 5 4 2
输出

7
备注:
对于30%的数据,n,A𝑖 ≤ 5。
对于50%的数据,n,A𝑖 ≤ 100。
对于100%的数据,n ≤ 105,1 ≤ A𝑖 ≤ 109。

自己值加上本身-1的值即为最大抗受值

#include <iostream>
#include <cstdio>
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 1e5 + 10;
int a[MAXN];
int main()
{
    int t;
    cin>>t;
    for(int i = 0; i < t; i++) {
        cin>>a[i];
        a[i] += i;
    }
    sort(a,a+t);
    cout<<a[t-1]<<endl;
    return 0;
}

题目描述
𝑅𝑒𝑘𝑖是一名武侦高狙击科的学生,武侦高也设有基础学科,现在她正
在完成生物课的作业。
给出一张𝑛个点𝑚条边的无向图,这张无向图描述了一个细胞,细胞有
三种:X型、Y型还是I型。

如图,虚线方向的链可以无限延伸,现在需要判断给定的图是哪一种
细胞,或者都不是。
输入描述:
第一行,两个正整数𝑛,𝑚。
接下来𝑚行,每行两个正整数𝑢, 𝑣描述一条无向边。
输出描述:
输出这种细胞的类型,若都不是输出NotValid。
示例1
输入

7 6
1 2
1 3
1 4
1 5
5 6
6 7
输出

X
示例2
输入

7 6
1 2
1 3
3 4
1 5
5 6
6 7
输出

Y
示例3
输入

2 1
1 2
输出

I
示例4
输入

8 7
1 2
1 3
1 4
4 5
5 6
5 7
5 8
输出

NotValid
备注:
对于100%的数据,2 ≤ 𝑛 ≤ 500,0 ≤ 𝑚 ≤ 𝑛*(𝑛−1)/2,没有重边和自环。

直接判断所有点度数的情况,注意看下虽然X型可能中间有其他乱入,但是四个角一定是要有的且只能四个角,图中的例子观察每个图的所有度数特征,先记录每个点的度数,然后用一个数组桶排序记录每个改度数的点有多少个,判断特征即可

#include<bits/stdc++.h>
using namespace std;
#define EPS 0.0000001
typedef long long LL;
int read(){ int v = 0, f = 1;char c =getchar();
while( c < 48 || 57 < c ){if(c=='-') f = -1;c = getchar();}
while(48 <= c && c <= 57) v = v*10+c-48, c = getchar();
return v*f;}
 
int deg[510];
int main()
{
    int c=1;
    int n,m;
    int i,j,k;
     
    n = read();
    m = read();
    memset(deg,0,sizeof(deg));
    for(i=0;i<m;i++){
        j = read();
        k = read();
        deg[k]++;
        deg[j]++;
    }
    vector<int> num_deg(6,0);
    for(i=1;i<=n;i++){
        if(deg[i]<=4)
        num_deg[deg[i]]++;
    }
    if(num_deg[1]==2 && num_deg[2]==(n-2)) printf("I\n");
    else if(num_deg[1]==3 && num_deg[3]==1 && num_deg[2]==(n-4))printf("Y\n");
    else if(num_deg[1]==4 && num_deg[4]==1 && num_deg[2]==(n-5)) printf("X\n");//四个角一度的点4个,4度的点1个,其他点应该都是2度的。
    else printf("NotValid\n");
    return 0;
}
posted @ 2017-10-10 22:15  Lawliet__zmz  阅读(220)  评论(0编辑  收藏  举报