[算法刷题题解笔记] 洛谷 P1011 [NOIP1998 提高组] 车站 [数学|斐波那契|推导]

简介: [算法刷题题解笔记] 洛谷 P1011 [NOIP1998 提高组] 车站 [数学|斐波那契|推导]

题目链接

题目大意

  • 根据题目给出的每个车站上下车人数的规律,以及测试点输入的数据:始发站上车人数a、车站数n、终点站下车人数m,编写程序,计算出所求的站点编号x火车发车时车上的人数

解题思路

  • 假设第二站上下车人数为x,推导每个车站火车发车时车上人数的公式表达式:
  • 推导出公式为:m = k1a + k2x
  • 其中k1 k2为a和x前的系数,a为始发站上车人数,x为第二站的上下车人数,m为终点站下车人数
  • k1_i = k1_(i-1) + k1_(i-2) - 1 从第四站开始为前两站系数之和 - 1
  • k2_i = k2_(i-1) + k2_(i-2) + 1 从第四站开始为前两站系数之和 + 1
  • 先根据a和x前的系数k1 k2的规律,求出最后一站前一站发车时车上人数表示公式的k1 k2,最后一站下车人数等于前一站上下车后车上人数(最后一站全部下)
  • 在求解最后一站前一站发车时车上人数表示公式的k1 k2的过程中,保存每一站发车时车上人数表示公式的k1 k2
  • 然后根据推导出公式求出未知数x
  • 最后利用推导公式和提前求解保存的每一站发车时车上人数表示公式的k1 k2,求解输出所求站点xi出发时的车上人数

截图代码

// package luogu.orange;
import java.io.*;
/**
 * ClassName: P1011
 * Package: luogu.orange
 * Description:
 *
 * @Author tcw
 * @Create 2023-06-08 23:44
 * @Version 1.0
 */
public class Main {
    // 快读快写
    private static StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
    private static PrintWriter out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out)));
    public static void main(String[] args) {
        // 始发站上车人数
        int a = readInt();
        // 车站数
        int n = readInt();
        // 终点站下车人数
        int m = readInt();
        // 所求站点编号
        int xi = readInt();
        // 根据推导,m = k1a + k2x
        // 其中k1 k2为a和x前的系数,a为始发站上车人数
        // x为第二站的上下车人数,m为终点站下车人数
        // k1_i = k1_(i-1) + k1_(i-2) - 1 从第四站开始为前两站系数之和-1
        // k2_i = k2_(i-1) + k2_(i-2) + 1 从第四站开始为前两站系数之和+1
        // 存储系数
        int[] k1 = new int[n];
        int[] k2 = new int[n];
        // 求解推导出的公式系数,并求解x
        // 由于最后一站下车人数等于前一站上下车后车上人数(最后一站全部下)
        for (int i = 1; i <= n - 1; i++) {
            if (i == 1) {
                k1[i] = 1;
                k2[i] = 0;
            } else if (i == 2) {
                k1[i] = 1;
                k2[i] = 0;
            } else if (i == 3) {
                k1[i] = 2;
                k2[i] = 0;
            } else {
                k1[i] = k1[i - 1] + k1[i - 2] - 1;
                k2[i] = k2[i - 1] + k2[i - 2] + 1;
            }
            // out.println(k1[i] +" " + k2[i]);
        }
        // 根据推导公式 m = k1a + k2x 求解x
        int x = (m - k1[n - 1] * a) / k2[n - 1];
        // 计算输出所求站点xi出发时的车上人数
        out.print(k1[xi] * a + k2[xi] * x);
        out.flush();
    }
    private static int readInt() {
        int in = 0;
        try {
            st.nextToken();
            in = (int) st.nval;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return in;
    }
}


相关文章
|
2月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--希尔排序
数据结构与算法(Java篇)笔记--希尔排序
|
20天前
|
算法
算法系列--链表刷题(二)(下)
算法系列--链表刷题(二)(下)
16 0
|
2月前
|
算法
算法沉淀 —— 动态规划篇(斐波那契数列模型)
算法沉淀 —— 动态规划篇(斐波那契数列模型)
24 0
|
2月前
|
机器学习/深度学习 算法 Python
LSTM(长短期记忆)网络的算法介绍及数学推导
LSTM(长短期记忆)网络的算法介绍及数学推导
22 0
|
2月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--快速排序
数据结构与算法(Java篇)笔记--快速排序
|
2月前
|
机器学习/深度学习 算法 搜索推荐
数据结构与算法(Java篇)笔记--归并排序
数据结构与算法(Java篇)笔记--归并排序
|
2月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--选择排序
数据结构与算法(Java篇)笔记--选择排序
|
11天前
|
机器学习/深度学习 人工智能 算法
基于DCT和扩频的音频水印嵌入提取算法matlab仿真
本文介绍了结合DCT和扩频技术的音频水印算法,用于在不降低音质的情况下嵌入版权信息。在matlab2022a中实现,算法利用DCT进行频域处理,通过扩频增强水印的隐蔽性和抗攻击性。核心程序展示了水印的嵌入与提取过程,包括DCT变换、水印扩频及反变换步骤。该方法有效且专业,未来研究将侧重于提高实用性和安全性。
|
1天前
|
算法 数据安全/隐私保护 计算机视觉
基于DCT变换的彩色图像双重水印嵌入和提取算法matlab仿真
**算法摘要:** - 图形展示:展示灰度与彩色图像水印应用,主辅水印嵌入。 - 软件环境:MATLAB 2022a。 - 算法原理:双重水印,转换至YCbCr/YIQ,仅影响亮度;图像分割为M×N块,DCT变换后嵌入水印。 - 流程概览:两步水印嵌入,每步对应不同图示表示。 - 核心代码未提供。
|
1天前
|
机器学习/深度学习 算法 数据可视化
Matlab决策树、模糊C-均值聚类算法分析高校教师职称学历评分可视化
Matlab决策树、模糊C-均值聚类算法分析高校教师职称学历评分可视化
10 0