Noip模拟题解题报告

Pro

题目链接

Sco

预计得分: 100+100+50=250 100 + 100 + 50 = 250

实际得分: 100+10+30=140 100 + 10 + 30 = 140

哇哇哇哇哇

Sol

sum

很简单的一道数学题

虽然有两个求和,但是第二个求和是等比数列的求和

直接公式就可以出了

因为要除法取模,所以逆元就可以了

#include<iostream>
#include<cstdio>
using namespace std;

const int mod = 1e9 + 7;
int n , m;
long long ans;

inline long long qpow(int x , int y) {
    if(y == 1)
        return x % mod;
    long long t = qpow(x , y/2) % mod;
    if(y % 2 == 0)
        return t * t % mod;
    return t * t % mod * x % mod;
}

inline long long inv(int x) {
    return qpow(x , mod-2);
}

int main() {
    freopen("sum.in","r",stdin);
    freopen("sum.out","w",stdout);
    scanf("%d%d",&n,&m);
    if(m == 1) {
        printf("%d",((n*(n+1)%mod)*inv(2))%mod);
        return 0;
    }
    for(int i=2; i<=n; i++)
        ans = (ans + ((i*(1-qpow(i,m))%mod)*inv(1-i))%mod) % mod;
    printf("%lld",(ans+m)%mod);
    return 0;
} 

tour

第二题也是非常的水,我也是推出了正解

赛后发现写炸了的原因是我当成单向边处理了

本题做法:贪心+最长路

写一写答案的表达式可以发现

最后的答案就是所有路径和的二倍减去距离1号点最远的距离

可以这么理解:我们假设所有的边都走一遍,但是题目没要求最后要回到出发点

因此可以少走一段距离,根据贪心思想,这段距离越长越好

就可以转化为求树上距离原点最长路问题

这时候可以把树当成图来处理,跑一遍最长路即可。

#include<iostream>
#include<cstdio>
#include<queue>
#include<algorithm>
using namespace std;

struct Node {
    int next , to , len;
};
Node e[2*50005];
struct Que {
    int num , len , frm;
    Que (int nn , int dd , int from) {
        num = nn , len = dd , frm = from;
    }
    bool operator < (const Que &a) const {
        return len < a.len;
    }
};
priority_queue<Que>q;
int n , tot , head[50005] , dis[50005] , ans;
inline int mymax(int a , int b) { return a>b?a:b; }

void add(int x , int y , int z) {
    tot++;
    e[tot].next = head[x];
    e[tot].to = y;
    e[tot].len = z;
    head[x] = tot;
}

int dij(int s) {
    int res = 0;
    dis[s] = 0;
    q.push(Que(s , dis[s] , 0));
    while(!q.empty()) {
        Que u = q.top();
        q.pop();
        if(u.len != dis[u.num])
            continue;
        for(int i=head[u.num]; i; i=e[i].next) {
            int v = e[i].to;
            if(v == u.frm)
                continue;
            if(dis[v] < dis[u.num] + e[i].len) {
                dis[v] = dis[u.num] + e[i].len;
                q.push(Que(v , dis[v] , u.num));            
            }
        }
    }
    for(int i=1; i<=n; i++)
        res = mymax(res , dis[i]);
    return res;
}

int main() {
    freopen("tour.in","r",stdin);
    freopen("tour.out","w",stdout);
    scanf("%d",&n);
    for(int i=1; i<n; i++) {
        int x , y , z;
        scanf("%d%d%d",&x,&y,&z);
        add(x , y , z);
        add(y , x , z);
        ans = ans + 2 * z;
    }
    printf("%d",ans-dij(1));
    return 0;
}

lucky

把题目完全读错还30分!

不说错误解法了,说我自己读懂题目后打了50分的解法。

直接搜索就行,搜索每一个位置的数字是几,这里用到容器:集合 set s e t

先一边输入一边把幸运数找出来,打上标记

然后深搜,搜索到的幸运数必须不在集合内才能继续搜索

搜完这一层之后,回溯一下,如果能搜到正好 k k 个元素

答案就加一

#include<iostream>
#include<cstdio>
#include<set>
using namespace std;

set<int>s;
int n , k , num[100005] , ans , flag , vis[100005];
int four , seven;

int check4(int opt , int data) {
    int t = 0;
    while(data) {
        if(data % 10 == 4)
            t++;
        data = data/10;
    }
    return t;
}

int check7(int opt , int data) {
    int t = 0;
    while(data) {
        if(data % 10 == 7)
            t++;
        data = data/10;
    }
    return t;
}

void dfs(int opt , int cnt) {
    if(cnt == k)
        ans++;
    for(int i=opt+1; i<=n; i++) {
        if(vis[i] && s.find(num[i])!=s.end())
            continue;
        if(vis[i]) {
            s.insert(num[i]);
            flag = 1;
        }
        dfs(i , cnt+1);
        if(flag)
            s.erase(num[i]);
    }
}

int main() {
    freopen("lucky.in","r",stdin);
    freopen("lucky.out","w",stdout);
    scanf("%d%d",&n,&k);
    for(int i=1; i<=n; i++) {
        scanf("%d",&num[i]);
        four = check4(i , num[i]);
        seven = check7(i , num[i]); 
        if((four&&!seven) || (!four&&seven))
            vis[i] = 1; 
    } 
    dfs(0 , 0);
    printf("%d",ans);
    return 0;
}
【基于QT的调色板】是一个使用Qt框架开发的色彩选择工具,类似于Windows操作系统中常见的颜色选取器。Qt是一个跨平台的应用程序开发框架,广泛应用于桌面、移动和嵌入式设备,支持C++和QML语言。这个调色板功能提供了横竖两种渐变模式,用户可以方便地选取所需的颜色值。 在Qt中,调色板(QPalette)是一个关键的类,用于管理应用程序的视觉样式。QPalette包含了一系列的颜色角色,如背景色、前景色、文本色、高亮色等,这些颜色可以根据用户的系统设置或应用程序的需求进行定制。通过自定义QPalette,开发者可以创建具有独特视觉风格的应用程序。 该调色板功能可能使用了QColorDialog,这是一个标准的Qt对话框,允许用户选择颜色。QColorDialog提供了一种简单的方式来获取用户的颜色选择,通常包括一个调色板界面,用户可以通过滑动或点击来选择RGB、HSV或其他色彩模型中的颜色。 横渐变取色可能通过QGradient实现,QGradient允许开发者创建线性或径向的色彩渐变。线性渐变(QLinearGradient)沿直线从一个点到另一个点过渡颜色,而径向渐变(QRadialGradient)则以圆心为中心向外扩散颜色。在调色板中,用户可能可以通过滑动条或鼠标拖动来改变渐变的位置,从而选取不同位置的颜色。 竖渐变取色则可能是通过调整QGradient的方向来实现的,将原本水平的渐变方向改为垂直。这种设计可以提供另一种方式来探索颜色空间,使得选取颜色更为直观和便捷。 在【colorpanelhsb】这个文件名中,我们可以推测这是与HSB(色相、饱和度、亮度)色彩模型相关的代码或资源。HSB模型是另一种常见且直观的颜色表示方式,与RGB或CMYK模型不同,它以人的感知为基础,更容易理解。在这个调色板中,用户可能可以通过调整H、S、B三个参数来选取所需的颜色。 基于QT的调色板是一个利用Qt框架和其提供的色彩管理工具,如QPalette、QColorDialog、QGradient等,构建的交互式颜色选择组件。它不仅提供了横竖渐变的色彩选取方式,还可能支持HSB色彩模型,使得用户在开发图形用户界面时能更加灵活和精准地控制色彩。
标题基于Spring Boot的二手物品交易网站系统研究AI更换标题第1章引言阐述基于Spring Boot开发二手物品交易网站的研究背景、意义、现状及本文方法与创新点。1.1研究背景与意义介绍二手物品交易的市场需求和Spring Boot技术的适用性。1.2国内外研究现状概述当前二手物品交易网站的发展现状和趋势。1.3论文方法与创新点说明本文采用的研究方法和在系统设计中的创新之处。第2章相关理论与技术介绍开发二手物品交易网站所涉及的相关理论和关键技术。2.1Spring Boot框架解释Spring Boot的核心概念和主要特性。2.2数据库技术讨论适用的数据库技术及其在系统中的角色。2.3前端技术阐述与后端配合的前端技术及其在系统中的应用。第3章系统需求分析详细分析二手物品交易网站系统的功能需求和性能需求。3.1功能需求列举系统应实现的主要功能模块。3.2性能需求明确系统应满足的性能指标和安全性要求。第4章系统设计与实现具体描述基于Spring Boot的二手物品交易网站系统的设计和实现过程。4.1系统架构设计给出系统的整体架构设计和各模块间的交互方式。4.2数据库设计详细阐述数据库的结构设计和数据操作流程。4.3界面设计与实现介绍系统的界面设计和用户交互的实现细节。第5章系统测试与优化说明对系统进行测试的方法和性能优化的措施。5.1测试方法与步骤测试环境的搭建、测试数据的准备及测试流程。5.2测试结果分析对测试结果进行详细分析,验证系统是否满足需求。5.3性能优化措施提出针对系统性能瓶颈的优化建议和实施方案。第6章结论与展望总结研究成果,并展望未来可能的研究方向和改进空间。6.1研究结论概括本文基于Spring Boot开发二手物品交易网站的主要发现和成果。6.2展望与改进讨论未来可能的系统改进方向和新的功能拓展。
1. 用户与权限管理模块 角色管理: 学生:查看个人住宿信息、提交报修申请、查看卫生检查结果、请假外出登记 宿管人员:分配宿舍床位、处理报修申请、记录卫生检查结果、登记晚归情况 管理员:维护楼栋与房间信息、管理用户账号、统计住宿数据、发布宿舍通知 用户操作: 登录认证:对接学校统一身份认证(模拟实现,用学号 / 工号作为账号),支持密码重置 信息管理:学生完善个人信息(院系、专业、联系电话),管理员维护所有用户信息 权限控制:不同角色仅可见对应功能(如学生无法修改床位分配信息) 2. 宿舍信息管理模块 楼栋与房间管理: 楼栋信息:名称(如 "1 号宿舍楼")、层数、性别限制(男 / 女 / 混合)、管理员(宿管) 房间信息:房间号(如 "101")、户型(4 人间 / 6 人间)、床位数量、已住人数、可用状态 设施信息:记录房间内设施(如空调、热水器、桌椅)的配置与完好状态 床位管理: 床位编号:为每个床位设置唯一编号(如 "101-1" 表示 101 房间 1 号床) 状态标记:标记床位为 "空闲 / 已分配 / 维修中",支持批量查询空闲床位 历史记录:保存床位的分配变更记录(如从学生 A 调换到学生 B 的时间与原因) 3. 住宿分配与调整模块 住宿分配: 新生分配:管理员导入新生名单后,宿管可按专业集中、性别匹配等规则批量分配床位 手动分配:针对转专业、复学学生,宿管手动指定空闲床位并记录分配时间 分配结果公示:学生登录后可查看自己的宿舍信息(楼栋、房间号、床位号、室友列表) 调整管理: 调宿申请:学生提交调宿原因(如室友矛盾、身体原因),选择意向宿舍(需有空位) 审批流程:宿管审核申请,通过后执行床位调换,更新双方住宿信息 换宿记录:保存调宿历史(申请人、原床位、新床位、审批人、时间) 4. 报修与安全管理模块 报修管理: 报修提交:学生选择宿舍、设施类型(如 "
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值