ACM第二周训练题目合集

简介: ACM第二周训练题目合集

 image.gif编辑已经写过了这个题目,所以不再赘述

image.gif编辑

1.这个题目就是学长让学习的本周算法题目,给了个基本概念,这个题也是非常简单。代码如下所示:

#include<stdio.h>
int main()
{
  int n,sum=0,i;
  scanf("%d",&n);
  printf("%d\n",n);
  int arr[100010];
  for(i=0;i<n;i++)
  {
    scanf("%d",&arr[i]);
    sum=sum+arr[i];
    printf("%d\n",sum);
  }
  return 0;
}
image.gif

image.gif编辑

这就是一道语法题目很简单,代码如下所示:(本人可能写的不是最牛的或者最简洁的代码)

#include<stdio.h>
int main()
{
  int y,m,d,i;
  int arr[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
  while(~scanf("%d/%d/%d",&y,&m,&d))
  {
    int sum=0;
    if((y%100!=0 && y%4==0)||(y%400==0))
    {
      arr[2]=29;
    }
    else arr[2]=28;
    if(m==1)
    {
      sum=d;
    }
    else if(m>1)
    {
      for(i=1;i<m;i++)
      {
        sum=sum+arr[i];
      }
      if(i==m)
      {
        sum=sum+d;
      }
    }
    printf("%d\n",sum);
  }
  return 0;
}

image.gif

image.gif编辑

这个题目其实就是前缀和算法我后面会出一期关于我学习AcWing算法课程的内容,里面还是会讲解我学习算法的心得和收获,这里我不过多讲述算法内容,代码如下:

#include<cstdio>
int main()
{
  int N,Q;
  scanf("%d %d",&N,&Q);
  long long int sum[N+1],temp=0;
  sum[0]=0;
  for(int i=1;i<=N;i++)
  {
    long long int a;
    scanf("%lld",&a);
    temp+=a;
    sum[i]=temp;
  }
  for(int i=1;i<=Q;i++)
  {
    int f,t;
    scanf("%d%d",&f,&t);
    printf("%lld\n",sum[t]-sum[f-1]);
  }
  return 0;
}

image.gif

image.gif编辑

目前做过几次这样的题目了,没啥难度,语法题目,看代码吧:

#include<stdio.h>
int fen(int n,int m)
{
  int r;
  if(n>m)
  {
    int temp=n;
    n=m;
    m=temp;
  }
  while((r=m%n)!=0)
  {
    m=n;
    n=r;
  }
  return n;
}
int main()
{
  int n,a,b,c,d,z,m;
  scanf("%d",&n);
  while(n>0)
  {
    scanf("%d %d %d %d",&a,&b,&c,&d);
    m=b*d;
    z=a*d+c*b;
    int c=fen(z,m);
    printf("%d %d\n",z/c,m/c);
    n--;
  }
  return 0;
}

image.gif

image.gif编辑

这个题目学长们安排其实就是考察我们的思维,如果看透了非常easy,代码如下所示:

#include<stdio.h>
#include<math.h>
int main()
{
  int t;
  scanf("%d",&t);
  while(t--)
  {
    int a,b,n;
    int i=0,j=0,count=0;
    scanf("%d %d %d",&a,&b,&n);
    while(a%2==0)
    {
      i++; a=a/2;
    }
    while(b%2==0)
    {
      j++; b=b/2;
    }
    count=pow(2,i+j);
    if(count>=n) printf("YES\n");
    else printf("NO\n");
  }
  return 0;
}

image.gif

image.gif编辑

我估计是因为学长们害怕我们不会,一直放这个题,代码如下所示:

#include<stdio.h>
int main()
{
  int n,r,i=0,j=0;
  char arr[1000];
  while(~scanf("%d %d",&n,&r))
  {
    if(n<0){
      printf("-");
      n=n-2*n;
    } 
    while(n>0)
    {
      ++i;
      arr[i]=n%r;
      n=n/r;
    }
    for(j=i;j>0;j--)
    {
      if(arr[j]>=10&&arr[j]<=16)
      {
        if(j!=1) printf("%c",arr[j]+55);
        else{
          printf("%c\n",arr[j]+55);
        } 
        i=0;
      }
      else
      {
        if(j!=1) printf("%d",arr[j]);
        else {
          printf("%d\n",arr[j]);
        }
        i=0;
      }
    }
  }
  return 0;
}

image.gif

image.gif编辑

真是大家好好学习英语吧,这么长我都自闭了,大家看看题意和思路吧

题意

有人要去上课,1代表有课,0代表没课

这个人在有两个及以上连续的没课的时候,才会回家

然后问你这个人得在学校呆多

题解:

直接暴力扫一遍就好了

有课会呆在学校,没课但是,上下都是课的,也会呆在学校

#include<stdio.h>
int main()
{
  int n,arr[100010];
  scanf("%d",&n);
  for(int i=1;i<=n;i++) scanf("%d",&arr[i]);
  int count=0;
  for(int i=1;i<=n;i++)
  {
    if(arr[i]==1) 
      count++;
    if(arr[i]==0&&arr[i-1]==1&&arr[i+1]==1)
      count++;
  }
  printf("%d\n",count);
  return 0;
}

image.gif

image.gif编辑

这是一道找规律问题 ,不难。

暴力递归完了

#include<stdio.h>
int fun(int n)
{
  if(n<=4)
  return n;
  else
  return fun(n-1)+fun(n-3);
} 
 int main()
 {
  int n;
  while(~scanf("%d",&n)&&n!=0)
  {
    printf("%d\n",fun(n));
  }
  return 0;
 }

image.gif

image.gif编辑

这个我一开始想的思路是把每一个数都放到数组里面然后快速排序,然后从最小值输出,后来发现这种方法是不行的,于是求助了一下csdn

题解:

将要删除的数字从头开始,让第一个与第二个比较大小,如果第一个大于第二个,则将第二个的值赋给第一个,第三个付给第二个,依次类推。第一个与第二个比完后,如果第一个大于第二个,则赋值后记一次数,然后退出复制的循环,再从头开始比较;否则,继续进行第三个与第二个的比较,依次类推,其实一句话就是贪心算法这个题目。

#include<stdio.h>
#include<string.h>
int main()
{
  int n;
  scanf("%d",&n);
  while(n--)
  {
    char arr[210];
    int k=0,i=0,j=0;
    scanf("%s %d",arr,&k);
    int len=strlen(arr);
    while(k--)
    {
      for(i=0;i<len-1;i++)
      {
        if(arr[i]>arr[i+1])
        {
          for(j=i;j<len-1;j++) 
            arr[j]=arr[j+1];
        }
      }
      len--;
    }
    for(i=0;i<len;i++) 
      printf("%c",arr[i]); 
    printf("\n");
  }
  return 0;
}

image.gif

image.gif编辑

做了好几次了这个题目,不说了看代码:

#include<stdio.h>
#include<math.h>
int main()
{
  int m,n,i=0,j=0,arr[100010];
  scanf("%d",&m);
  while(m--)
  {
    scanf("%d",&n);
    for(i=0;i<n;i++) scanf("%d",&arr[i]);
    int min=100000000;
    for(i=0;i<n;i++)
    {
      int count=0;
      for(j=0;j<n;j++)
      {
        count+=abs(arr[i]-arr[j]);
      }
      if(min>count)
      {
        min=count;
      }
    }
    printf("%d\n",min);
  } 
  return 0;
}

image.gif

image.gif编辑

这一道题目收获颇丰,我学到了判断素数的新的方法埃式筛选法:

#include<stdio.h>
#include<math.h>
int a[1000005];
//1-10^6范围内的素数筛
void init()//埃氏筛求1-10^6内的所有素数
{
  //a[i]=0代表是素数 a[i]=1代表不为素数
  for(int i=2;i<1000005;i++)
  {
    if(a[i]==0)//意味着当前数为素数
    {
      for(int j=i*2;j<=1000005;j+=i)
      {
        a[j]=1;//j代表 i的整数倍,因为j是i的整数倍
             //因此j一定不是素数 标记为1
      }
    }
  }
}
int main()
{
  int t;
  init();
  scanf("%d",&t);
  for(int i=0;i<t;i++)
  {
    long long n;
    scanf("%lld",&n);
    long long x=sqrt(n);
    if(x*x==n&&x>1&&a[x]==0)
    {
      printf("YES\n");
    }
    else 
    {
      printf("NO\n");
    }
  }
  return 0;
}
//注释是学长教的

image.gif

本周训练总结:

1.收获:学习到了前缀和算法,以及了解了贪心算法,知道了埃式筛选法。

2.规划:继续学习acwing算法和数据结构,坚持在x-mind上边打卡。

相关文章
|
8月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-194 审美课
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-194 审美课
43 0
|
8月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-641 下次上什么课
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-641 下次上什么课
56 0
|
搜索推荐 C++
十大经典排序算法整理汇总(附代码)
十大经典排序算法整理汇总(附代码)
102 0
|
索引
蓝桥杯备战 每日训练3道 真题解析
蓝桥杯备战 每日训练3道 真题解析
106 0
蓝桥杯备战 每日训练3道 真题解析
ACM训练题目【股票买卖Ⅱ】
3.思路与代码 贪心思路:看相邻的两天,只要后一天价格比前一天高,那么就无脑进行交易一次,最终得到一个全局的最优解
82 0
ACM训练题目【股票买卖Ⅱ】
|
算法
ACM算法训练【贪心合集】
ACM算法训练【贪心合集】
135 0
ACM算法训练【贪心合集】
|
机器学习/深度学习
《考察数据科学家支持向量机(SVM)知识的25道题,快来测测吧》电子版地址
考察数据科学家支持向量机(SVM)知识的25道题,快来测测吧
86 0
《考察数据科学家支持向量机(SVM)知识的25道题,快来测测吧》电子版地址
|
C语言 C++
蓝桥杯入门训练试题集
蓝桥杯入门训练试题集
113 0
|
算法 搜索推荐
ACM 选手带你玩转分治算法!
ACM 选手带你玩转分治算法!
ACM 选手带你玩转分治算法!