比赛:ICPC Asia Taipei-Hsinchu Regional 2019 2020.4.1

 C. Are They All Integers?

题意:是给定n个数字判断对任意的(a[j]-a[i])/a[k]一定要是整数。

题解:

一开始以为用枚举会超时不过还是试了下,没想到没超时,直接过了,题目很简单,简单枚举就好。

#include<iostream>
using namespace std;
int main(){
    int n,a[1001],sum;
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>a[i];
    }
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            for(int k=0;k<n;k++){
                if(i!=j&&i!=k&&j!=k){
                    sum=a[i]-a[j];
                    if(sum%a[k]!=0){
                          cout<<"no"<<endl;
                          return 0;
                    }
                }
            }
        }
    }
    cout<<"yes"<<endl;
    return 0;
}

 D. Tapioka

题目意思:给3个字符串去掉其中所有的"bubble"和"tapioka"如果没有字符串了就输出nothing(签到题,比较简单)

题解:

根据题意做就好

#include <iostream>
#include<map>
#include<fstream>
using namespace std;
int main()
{
    int n,i,j,k=0;
    map<string,int>h;
    string s[3],a,b,c;
    for(i=0; i<3; i++)
    {
        cin>>s[i];
        if(s[i]=="bubble"||s[i]=="tapioka")
        {
            h[s[i]]=0;
        }
        else
        {
            h[s[i]]=1;
        }
    }
    for(i=0; i<3; i++)
    {
        if(h[s[i]]==1)
        {
            k=1;
            cout<<s[i]<<' ';
        }
    }
    if(k==0)
    {
        cout<<"nothing";
    }

    return 0;
}

 K. Length of Bundle Rope

题目意思:

给定n个盒子用绳子把他们连起来,问最少需要多少的绳子,把多大的盒子连起来绳子大小就加上多少。

题解:

一开始想用dp,发现不用,就是把其中最小的两个盒子加起来,然后再判断,再把其中两个盒子加起来,直到n=2时,进行最后一个相加就好

#include<iostream>
#include<algorithm>
using namespace std;
int main(){
    int t,n,sum;
    int a[1001];
    cin>>t;
    while(t--){
        sum=0;
        cin>>n;
     for(int i=0;i<n;i++){
         cin>>a[i];
     }
     while(n>1){//如果有盒子可以相加,就继续循环
       sort(a,a+n);
       sum=sum+a[0]+a[1];//将2个最小的盒子加起来n该-1
       a[0]=a[0]+a[1];
       for(int i=1;i<n;i++){
           a[i]=a[i+1];
       }
       n--;//加起来后n-1
     }
     cout<<sum<<endl;
    }
    return 0;
}

 

上一篇:5_Django注册


下一篇:2019-2020 ICPC Asia Taipei-Hsinchu Regional Contest 训练记录