中南林业科技大学2020新生赛(2) 题解

字符统计

https://ac.nowcoder.com/acm/contest/9165/A

由于考试复习繁忙,具体题解思路暂未更新给出,非常抱歉。
这里先给出题目标程,稍后有空闲时间会更新题解思路。

A:

#include <bits/stdc++.h>
using namespace std;
set <char> st;
string s;
int main()
{
    cin>>s;
    for(int i=0;i<s.size();i++) st.insert(s[i]);
    cout<<st.size()<<endl;
}

B:

Python:

n=int(input())
if n&1 : print 1
else : print 2

C++:

#include <bits/stdc++.h>
using namespace std;
string s;
int main()
{
    cin>>s;
    int n=s[s.size()-1]-’0’;
    if(n&1) printf("1\n");
    else printf("2\n");
}

C:

#include <bits/stdc++.h>
using namespace std;
#define N 30
long long a[N]; 
long long b[N];
long long gcd(long long a,long long b)
{
    return b==0?a:gcd(b,a%b);
}
int main() {
    long long t,m;
    scanf("%lld",&t);
    while(t--)
    {
        scanf("%lld", &m);
        a[1] = 0; a[2] = 1;
        b[1] = 1; b[2] = 2;
        for (int i = 3; i <= m; i++) 
        {
            a[i] = (i - 1) * (a[i - 1] + a[i - 2]);         
            b[i] = b[i - 1] * i;
        }
        long long p=gcd(a[m],b[m]);
        printf("%lld/%lld\n",a[m]/p,b[m]/p);
    }
}

D:

#include <bits/stdc++.h>
using namespace std;
#define ll long long
const ll mod=1e9+7;
ll qpow(ll base,ll power)
{
    ll res=1;
    while(power)
    {
        if(power&1) res=res*base%mod;
        base=base*base%mod;
        power>>=1;
    }
    return res%mod;
}
int main()
{
    ll n;
    scanf("%lld",&n);
    printf("%lld\n",(qpow(2,n)-1+mod)%mod);
}

E:

#include<fstream> 
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<cstdio>
#define oo 1147483647
using namespace std;
int m,n;
int a[100010],tt,ans;
int cmp(const void *a,const void *b)
{
    return *(int *)a-*(int *)b;
}
int main()
{
    //freopen("orz.in","r",stdin);
    //freopen("orz.out","w",stdout);
    int i;
    scanf("%d",&n);
    for (i=1;i<=n;i++)
    {
        scanf("%d",&a[i]);
    }
    a[n+1]=1<<29;
    a[0]=-oo;
    qsort(a+1,n,sizeof(int),cmp);
    scanf("%d",&m);
    int x1,x2,y1,y2;
    for (i=1;i<=m;i++)
    {
        scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
        ans=0;
        if ((y1>0&&y2>0)||(y1<0&&y2<0))
        {
            ans=(int)abs((double)(y1-y2))+(int)abs((double)(x1-x2));
            printf("%d\n",ans);
            continue;
        }
        if (x1>x2) swap(x1,x2);
        ans=oo;
        int l=1,r=n,mid;
        while (l<=r)
        {
              mid=(l+r)>>1;
              if (a[mid]>=x1 && a[mid-1]<x1) 
              {
                  if (ans>(a[mid]-x1+abs(a[mid]-x2))) ans=a[mid]-x1+abs(a[mid]-x2);
                  if (mid>1) if (ans>(x1-a[mid-1]+abs(a[mid-1]-x2))) ans=x1-a[mid-1]+abs(a[mid-1]-x2);
                  break;
              }
              if (a[mid]<x1) l=mid+1;
              if (a[mid]>x1) r=mid-1;
        }
        l=1;r=n;mid;
        while (l<=r)
        {
              mid=(l+r)>>1;
              if (a[mid]<=x2 && a[mid+1]>x2) 
              {
                      if (ans>(x2-a[mid]+abs(x1-a[mid]))) ans=x2-a[mid]+abs(x1-a[mid]);
                      if ((mid+1)<=n)if (ans>(a[mid+1]-x2+abs(x1-a[mid+1]))) ans=a[mid+1]-x2+abs(x1-a[mid+1]);
                      break;
              }
              if (a[mid]<x2) l=mid+1;
              if (a[mid]>x2) r=mid-1;
        }
        ans+=(int)abs((double)(y1-y2));
        printf("%d\n",ans);
    }
    return 0;
}

F:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <string>
#include <algorithm>
#include <cmath>
using namespace std;
#define int long long
long long f[500100];
bool b[500100];
signed main()
{
    int n;
    while (scanf("%lld", &n) != EOF)
    {
        memset(b, 0, sizeof(b));
        for (int i = 1; i <= n; i++) f[i] = i;
        for (int i = 2; i <= n; i++)
        {
            if (b[i]) continue;

            for (int j = i; j <= n; j += i)
            {
                f[j] = (f[j] / i) * (i - 1);
                b[j] = 1;
            }
        }
        int re = 1;
        for (int i = 2; i <= n; i++)
        {
            re += f[i] * 2;
        }
        printf("%lld\n", re + 2);
    }
    return 0;
}

G:

#include <iostream>
#include <algorithm>
#include <string.h>
using namespace std;
#define ll long long
const ll INF = 9999999999999;
ll n, sta;
const int N = 1010;
ll ans = 0;
struct node
{
    ll x, c, d;
    bool operator < (const node& rhs)
    {
        return abs(x) < abs(rhs.x);
    }
}L[N],R[N];
ll f[N][N][2];
ll sumL[N], sumR[N];
int main()
{
    scanf("%lld%lld", &n, &sta);
    int topL = 0, topR = 0;
    L[0].x = 0, R[0].x = 0;
    ans = 0;
    memset(sumL, 0, sizeof(sumL)); memset(sumR, 0, sizeof(sumR));
    for (int i = 1; i <= n; i++)
    {
        ll x, c, d;
        scanf("%lld%lld%lld", &x, &c, &d);
        if (x > sta)
        {
            R[++topR].x = x - sta;
            R[topR].c = c;
            R[topR].d = d;
        }
        else if (x < sta)
        {
            L[++topL].x = x - sta;
            L[topL].c = c;
            L[topL].d = d;
        }
        ans += c;
    }
    sort(L + 1, L + 1 + topL);
    sort(R + 1, R + 1 + topR);
    for (int i = 1; i <= topL; i++)
    {
        sumL[i] = sumL[i - 1] + L[i].d;
    }
    for (int i = 1; i <= topR; i++)
    {
        sumR[i] = sumR[i - 1] + R[i].d;
    }
    for (int i = 1; i <= topL; i++)
    {
        f[i][0][0] = f[i - 1][0][0] + abs(L[i].x - L[i - 1].x) * (sumL[topL] - sumL[i - 1] + sumR[topR]);
    }
    for (int i = 1; i <= topR; i++)
    {
        f[0][i][1] = f[0][i - 1][1] + abs(R[i].x - R[i - 1].x) * (sumR[topR] - sumR[i - 1] + sumL[topL]);
    }
    for (int i = 1; i <= topL; i++)
    {
        for (int j = 1; j <= topR; j++)
        {
            //i是新到的点
            f[i][j][0] = min( (i==1?INF:(f[i - 1][j][0] + (abs(L[i].x - L[i - 1].x) * (sumL[topL] - sumL[i - 1] + sumR[topR] - sumR[j])))),
                f[i - 1][j][1] + (abs(L[i].x - R[j].x) * (sumL[topL] - sumL[i - 1] + sumR[topR] - sumR[j])) );
            //j是新到的点
            f[i][j][1] = min( (f[i][j - 1][0] + (abs(L[i].x - R[j].x) * (sumL[topL] - sumL[i] + sumR[topR] - sumR[j-1]))),
                j==1?INF:(f[i][j - 1][1] + (abs(R[j].x - R[j - 1].x) * (sumL[topL] - sumL[i] + sumR[topR] - sumR[j-1]))) );
        }
    }
    printf("%lld\n", ans + ( min(topR==0?INF:f[topL][topR][1], topL==0?INF:f[topL][topR][0])) );
}

H:

#include <bits/stdc++.h>
using namespace std;
#define MAX 247

int M,N;

int A[MAX][MAX];

int R[MAX][MAX];
int C[MAX][MAX];

int G[MAX*MAX][2];
int PR[MAX*MAX]; 
int PC[MAX*MAX];

int r,c;

int augment()
{
  int buf[MAX*MAX];
  int S[MAX*MAX];
  int zbuf, kbuf;
  int i, found, v, vb, va, tmp;
  int x;

  zbuf = kbuf = 0;
  for(i = 0; i < c; i++) S[i] = -1;
  for(i = 0; i < r; i++)
    if (PR[i] < 0) buf[kbuf++] = i;
  found = 0;
  while (zbuf < kbuf && !found) {
    v = buf[zbuf++];
    x = G[v][1];
    for(x=G[v][1]; x<N && A[G[v][0]][x]!=2; x++)
      if (A[G[v][0]][x]==0) {
        vb=C[G[v][0]][x];
        if (S[vb] < 0 && PC[vb] != v) {
          S[vb] = v;
          if (PC[vb] < 0) {
            found = 1;
            while (vb >= 0) {
              va = S[vb];
              tmp = PR[va];
              PR[va] = vb;
              PC[vb] = va;
              vb = tmp;
            }
            break;
          }
          buf[kbuf++] = PC[vb];
        }
      }
  }
  return found;
}


int main()
{
  int i,j,m,x;
  scanf("%d %d",&M,&N);
  for (i=0;i<M;i++) 
    for (j=0;j<N;j++)
      scanf("%d",&A[i][j]);
  c=0;
  for (j=0;j<N;j++) {
    for (i=0;i<M;i++) {
      if (A[i][j]==2) c++;
      else C[i][j]=c; 
    }
    c++;
  }
  r=0;
  for (i=0;i<M;i++) {
    G[r][0]=i; G[r][1]=0;
    for (j=0;j<N;j++) {
      if (A[i][j]==2) {r++; G[r][0]=i; G[r][1]=j+1;}
      else R[i][j]=r; 
    }
    r++;
  }

  for (i = 0; i < r; i++) PR[i] = -1;
  for (i = 0; i < c; i++) PC[i] = -1;
  for (m = 0; augment(); m++);

  printf("%d\n",m);         
  return 0;
}

I:

#include<stdio.h>
#include<string.h>

int sum[300001];
int max0[300001];
int max1[300001];
int left0[300001];
int right0[300001];
int left1[300001];
int right1[300001];
bool b[300001];
int z[300001];
int a[100001];

void updata(int x,int l,int m,int h)
{
    b[x]=true;
    sum[x]=sum[2*x]+sum[2*x+1];
    max1[x]=max1[2*x];
    if (max1[x]<max1[2*x+1]) max1[x]=max1[2*x+1];
    if (max1[x]<right1[2*x]+left1[2*x+1]) max1[x]=right1[2*x]+left1[2*x+1];
    max0[x]=max0[2*x];
    if (max0[x]<max0[2*x+1]) max0[x]=max0[2*x+1];
    if (max0[x]<right0[2*x]+left0[2*x+1]) max0[x]=right0[2*x]+left0[2*x+1];
    if (left1[2*x]==m-l+1) left1[x]=left1[2*x]+left1[2*x+1];
    else left1[x]=left1[2*x];
    if (right1[2*x+1]==h-m) right1[x]=right1[2*x]+right1[2*x+1];
    else right1[x]=right1[2*x+1];
    if (left0[2*x]==m-l+1) left0[x]=left0[2*x]+left0[2*x+1];
    else left0[x]=left0[2*x];
    if (right0[2*x+1]==h-m) right0[x]=right0[2*x]+right0[2*x+1];
    else right0[x]=right0[2*x+1];
    if (z[2*x]==z[2*x+1]) z[x]=z[2*x];
    else z[x]=2;
}

void change2(int x,int l,int h,int dd)
{
    int s0,s1;
    if (dd==0)
    {
        s0=h-l+1;
        s1=0;
    }
    else
    {
        s0=0;
        s1=h-l+1;
    }
    sum[x]=s1;
    max0[x]=s0;
    left0[x]=s0;
    right0[x]=s0;
    max1[x]=s1;
    left1[x]=s1;
    right1[x]=s1;
    z[x]=dd;
    b[x]=false;
}

void change(int x,int l,int h)
{
    if (z[x]<=1) change2(x,l,h,1-z[x]);
    else
    {
        b[x]=!b[x];
        int pp;
        pp=max1[x];
        max1[x]=max0[x];
        max0[x]=pp;
        pp=left1[x];
        left1[x]=left0[x];
        left0[x]=pp;
        pp=right1[x];
        right1[x]=right0[x];
        right0[x]=pp;
        sum[x]=h-l+1-sum[x];
    }
}

void datadown(int x,int l,int m,int h)
{
    if (b[x]) return;
    if (z[x]<=1)
    {
        change2(2*x,l,m,z[x]);
        change2(2*x+1,m+1,h,z[x]);
    }
    else
    {
        change(2*x,l,m);
        change(2*x+1,m+1,h);
    }
    b[x]=true;
}

void build(int x,int l,int h)
{
    if (l==h) change2(x,l,h,a[l]);
    else
    {
        int m=(l+h)/2;
        build(2*x,l,m);
        build(2*x+1,m+1,h);
        updata(x,l,m,h);
    }
}

void insert(int x,int l,int h,int ll,int hh,int dd)
{
    if (l==ll&&h==hh)
    {
        if (dd<=1) change2(x,l,h,dd);
        else change(x,l,h);
    }
    else
    {
        int m=(l+h)/2;
        datadown(x,l,m,h);
        if (hh<=m) insert(2*x,l,m,ll,hh,dd);
        else
        {
            if (ll<=m) 
            {
                insert(2*x,l,m,ll,m,dd);
                insert(2*x+1,m+1,h,m+1,hh,dd);
            }
            else insert(2*x+1,m+1,h,ll,hh,dd);
        }
        updata(x,l,m,h);
    }
}

int query0(int x,int l,int h,int ll,int hh)
{
    if (l==ll&&h==hh) return sum[x];
    else
    {
        int m=(l+h)/2;
        datadown(x,l,m,h);
        if (hh<=m) return query0(2*x,l,m,ll,hh);
        else
            if (ll<=m) return query0(2*x,l,m,ll,m)+query0(2*x+1,m+1,h,m+1,hh);
            else return query0(2*x+1,m+1,h,ll,hh);
    }
}

int query1(int x,int l,int h,int ll,int hh)
{
    if (l==ll&&h==hh) return max1[x];
    else
    {
        int m=(l+h)/2;
        datadown(x,l,m,h);
        if (hh<=m) return query1(2*x,l,m,ll,hh);
        else
        {
            if (ll<=m)
            {
                int m1=query1(2*x,l,m,ll,m);
                int m2=query1(2*x+1,m+1,h,m+1,hh);
                int mm;
                if (m1>m2) mm=m1;
                else mm=m2;
                int r1,l1;
                if (right1[2*x]>m-ll+1) r1=m-ll+1;
                else r1=right1[2*x];
                if (left1[2*x+1]>hh-m) l1=hh-m;
                else l1=left1[2*x+1];
                if (mm>r1+l1) return mm;
                else return r1+l1;
            }
            else return query1(2*x+1,m+1,h,ll,hh);
        }
    }
}

int main()
{
    int n;
    int t,p;
    int i;
    int op,b,c;
    //freopen("operation.in","r",stdin);
    //freopen("operation.out","w",stdout);
    scanf("%d%d",&n,&t);
    for (i=0;i<n;i++)
        scanf("%d",&a[i]);
    build(1,0,n-1);
    for (p=1;p<=t;p++)
    {
        scanf("%d",&op);
        scanf("%d%d",&b,&c);
        if (op==0) insert(1,0,n-1,b,c,0);
        if (op==1) insert(1,0,n-1,b,c,1);
        if (op==2) insert(1,0,n-1,b,c,2);
        if (op==3) printf("%d\n",query0(1,0,n-1,b,c));
        if (op==4) printf("%d\n",query1(1,0,n-1,b,c));
    }
    fclose(stdin);
    fclose(stdout);
    return 0;
}
全部评论

相关推荐

评论
5
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务