第六届题目

奖券数目

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char *argv[])
{
  int cnt=0;
  for(int i=10000;i<=99999;i++)
  {
    int t=i;
    int flag=1;
    while(t)
    {
      if(t%10==4) 
      {
        flag=0;
        break;
      }
      t/=10;
    }
    if(flag) cnt++;
  }
  printf("%d",cnt);
  return 0;
}

星系炸弹(日期问题)

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char *argv[])
{
  int month_day[]={0,31,28,31,30,31,30,31,31,30,31,30,31};
  int allday=1000,days=52;
  int y=0,m=0,d=0;
  for(int year=2015;year<=2020;year++)
  {
    if((year%400==0)||(year%4==0&&year%100!=0)) month_day[2]=29;
    else month_day[2]=28;
    for(int month=1;month<=12;month++)
    {
      for(int day=1;day<=month_day[month];day++)
      {
        days++;
        if(days==1000) 
        {
          y=year;
          m=month;
          d=day;
        }
      }
    }
  }
  printf("%d-%02d-%02d",y,m,d);
  return 0;
}

三羊献瑞

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char *argv[])
{
  printf("1085");
  return 0;
}

移动距离

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char *argv[])
{
  int w,m,n;
  scanf("%d %d %d",&w,&m,&n);
  int a1,a2,b1,b2;
  a1=(m-1)/w+1;
  a2=(n-1)/w+1;
  if(a1%2==0)
  {
    b1=w-((m+w)%w)+1;
  }
  else b1=((m+w)%w);
  if(a2%2==0)
  {
    b2=w-((n+w)%w)+1;
  }
  else b2=((n+w)%w);
  int sum=0;
  sum=abs(a2-a1)+abs(b2-b1);
  printf("%d",sum);
  return 0;
}

生命之树(树形DP+DFS)

给定一棵树,每个节点有权值(可正可负),求权值和最大的连通子图(子树)

cs 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAX 100005

typedef long long ll;
const ll INF=1e18;

//邻接表存储图
typedef struct AdjNode
{
  int v;//邻居节点编号
  struct AdjNode *next;//下一个邻居
}AdjNode;

typedef struct AdjList
{
  AdjNode *head;//链表头指针
}AdjList;

AdjList graph[MAX];//图的邻接表数组
ll val[MAX];
ll dp[MAX];
ll maxsum=0;

void add(int u,int v)
{
  AdjNode *newnode=(AdjNode*)malloc(sizeof(AdjNode));
  newnode->v=v;
  newnode->next=graph[u].head;
  graph[u].head=newnode;
  newnode=(AdjNode*)malloc(sizeof(AdjNode));
  newnode->v=u;
  newnode->next=graph[v].head;
  graph[v].head=newnode;
}

void dfs(int u,int parent)
{
  dp[u]=val[u];//初始化为节点自己的权值
  AdjNode *p=graph[u].head;
  while(p!=NULL)
  {
    int v=p->v;
    if(v!=parent)//避免回到父节点
    {
      dfs(v,u);//先递归处理字节点
      if(dp[v]>0)//如果子节点的贡献为正
      {
        dp[u]+=dp[v];//就累加到当前节点
      }
    }
    p=p->next;
  }
  if(dp[u]>maxsum) maxsum=dp[u];//更新全局最大值
}

void free_graph(int n)
{
  for(int i=1;i<=n;i++)
  {
    AdjNode *p=graph[i].head;
    while(p!=NULL)
    {
      AdjNode *t=p;
      p=p->next;
      free(t);
    }
    graph[i].head=NULL;
  }
}

int main(int argc, char *argv[])
{
  int n;
  scanf("%d",&n);
  memset(graph,0,sizeof(graph));
  for(int i=1;i<=n;i++)
  {
    scanf("%lld",&val[i]);
  }
  for(int i=0;i<n-1;i++)
  {
    int u,v;
    scanf("%d %d",&u,&v);
    add(u,v);
  }
  dfs(1,-1);
  printf("%lld",maxsum);
  free_graph(n);
  return 0;
}
相关推荐
05候补工程师3 分钟前
【考研高数核心突破】极限的本质、高频解题套路与海涅定理深度解析(附经典例题思维导图式拆解)
经验分享·笔记·考研·算法
智者知已应修善业7 分钟前
【51单片机8个LED的花样12亮34熄56间隔78闪烁3秒3闪烁】2023-11-4
c++·经验分享·笔记·算法·51单片机
老鱼说AI13 分钟前
统计学习方法第五章:从浅入深解析决策树
人工智能·深度学习·算法·决策树·机器学习·学习方法
KaMeidebaby15 分钟前
卡梅德生物技术快报|蛋白修饰调控 NETosis 分子机制及实验研究进展
前端·数据库·人工智能·算法·百度
初中就开始混世的大魔王19 分钟前
5 Fast DDS-Discovery
网络·c++·算法·中间件
Deep-w20 分钟前
【MATLAB】基于模型预测控制的自适应巡航车辆过渡工况安全控制研究
开发语言·人工智能·算法·机器学习·matlab
运行时记录21 分钟前
Sirchmunk 让搜索随查询自进化
算法
浮生望25 分钟前
双指针算法面试通关指南:从入门到精通
算法
SimpleLearingAI28 分钟前
PyTorch & Numpy 实现线性回归详解
人工智能·算法·多模态大模型
papership28 分钟前
【入门级-数据结构-1、线性结构:链 表(单链表、双向链表、循环链表 )】
数据结构·算法·链表