第十七次CCF-CSP算法(含C++源码)

第十七次CCF-CSP认证

小明种苹果


输入输出:


题目链接

AC代码

cpp 复制代码
#include<iostream>
using namespace std;
int n,m;
int res,res3;
int sum;
int res2=1;
int main(){
    cin >>n>>m;
   
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m+1;j++)
        {
            int x;
            cin >>x;
            res+=x;
            if(j!=1) 
            sum-=x;  
        }
        if(sum>res3 )
        {
            res3=sum;
              res2=i;
        }
        sum =0;
    }

    cout <<res<<' '<<res2<<' '<<res3<<endl;
    return 0;
}

小明种苹果(续)

题目链接

输入输出:

AC代码

链接:源码地址

cpp 复制代码
#include<iostream>
#include <algorithm>

using namespace std;
typedef long long int ll;
int apple[1005][1005];  // 存储每棵树的观测记录
int rem[1005];          // 记录每棵树最终剩余的苹果数
bool down[1005];        // 标记每棵树是否发生过苹果掉落,初始值为false

int main(){
    ios::sync_with_stdio(false);  // 加快输入输出速度
    cin.tie(0);
    int N;  // 苹果树的棵数
    int D=0;  // 发生苹果掉落的苹果树的数量
    ll T=0;   // 剩余的果子总数
    ll E=0;   // 连续三棵树都发生掉落的组数
    cin>>N;
    
    // 处理每棵苹果树的观测记录
    for(int i=1;i<=N;i++){
        int m;  // 当前树的观测记录数
        cin>>m;
        bool flag = false;  // 标记当前树是否发生了苹果掉落
        
        // 处理当前树的每条观测记录
        for(int j=1;j<=m;j++){
            cin>>apple[i][j];
            
            // 若记录为正数,表示直接更新苹果数
            if(apple[i][j]>0){
                // 若当前记录的苹果数小于之前的记录,说明发生了掉落
                if(rem[i]>apple[i][j]){
                    flag = true;
                }
                rem[i]=apple[i][j];  // 更新当前苹果树的苹果数
            }
            // 若记录为负数,表示苹果数减少
            else{
                rem[i]+=apple[i][j];  // 更新当前苹果树的苹果数
            }
        }
        
        // 若当前树发生了掉落,更新相关统计
        if(flag){
            ++D;  // 掉落树的数量加1
            down[i]= true;  // 标记当前树发生了掉落
        }
        T+=rem[i];  // 累加当前树的剩余苹果数到总数
    }
    
    // 处理环形结构:将最后两棵树的状态复制到N+1和N+2位置
    down[N+1]=down[1];
    down[N+2]=down[2];
    
    // 统计连续三棵树都发生掉落的组数
    for(int i=1;i<=N;i++){
        if(down[i]&&down[i+1]&&down[i+2]){
            ++E;  // 若当前树及其后两棵树都掉落,组数加1
        }
    }
    
    // 输出结果
    cout<<T<<" "<<D<<" "<<E<<endl;
    return 0;
}

后面好难哈哈 小手冰凉

相关推荐
Evand J2 分钟前
MATLAB例程——基于分批运输与最近邻优化的垃圾运输路径规划,n个垃圾收集点,每点有固定垃圾量,车辆从处理厂出发收集垃圾后返回,目标是最小化总行驶距离
开发语言·matlab
@老蝴11 分钟前
C语言 — 内存函数和数据的存储
c语言·开发语言
编码小笨猪18 分钟前
简说Qt信号和槽
开发语言·qt
2401_8769075235 分钟前
IEC 60034-30-1标准解析:旋转电机能效分级与全球影响
网络·数据结构·经验分享·科技·学习方法
滴水之功1 小时前
C语言数据结构-链式栈
linux·c语言·数据结构
无垠的广袤1 小时前
【萤火工场GD32VW553-IOT开发板】ADC电压的LabVIEW采集
c++·单片机·嵌入式硬件·物联网·labview
少可爱1 小时前
对接钉钉消息样例:DING消息、机器人
java·开发语言·钉钉
十五年专注C++开发1 小时前
CMake基础:CMakeLists.txt 文件结构和语法
开发语言·c++·cmake·跨平台编译
hjjdebug1 小时前
std::initialzer_list 与花括号{}数据列表
c++·initializer·数据列表·花括号数据列表·类型参数可变·参数个数可变
虾球xz1 小时前
游戏引擎学习第309天:用于重叠检测的网格划分
c++·学习·算法·游戏引擎