zoukankan      html  css  js  c++  java
  • 二模 (3) day1

    第一题:

    题目描述:

    一个数列定义如下:f(1) = 1,f(2) = 1,f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7。给定 A,B 和 n 的值,要求计算 f(n)的值。(1≤ A, B ≤1000, 1 ≤n≤100,000,000)。

    解题过程:

    1.方法一:矩阵乘法。

    2.方法二:hash。如果 Ak,Ak+1  确定了,那么Ak+2 就确定了,而Ak,Ak+1 的值都是小于7的,所以做个二维hash,记录Ak,Ak+1  第一次出现的位置,就可以判断循环节。

    初始得分100。


    第二题:

    题目描述:

    设 G 为有 n 个顶点的有向无环图,G 中各顶点的编号为 1 到 n,且当<i,j>为 G 中的一条边时有i < j。设 w(i,j)为边<i,j>的长度,请设计算法,计算图 G 中<1,n>间的最长路径。n<=1500

    解题过程:

    1.直接dp,反向存边,F[i]=max{F[j]+w[i][j]}  j<i;

    初始得分100.


    第三题:

    题目大意:

    给出4*4的01矩阵,每次可以选择一个点,把它和它上下左右的点(如果存在) xor 1。

    求初始状态到给出状态的最少步数。

    解题过程:

    1.没什么特别地技巧,直接宽搜就好,状态数比较少。用一个int压位保存状态(其实不压也行,空间足够)。hash判重即可。

    初始得分100.

    好水的一天。。用来提高信心了。

  • 相关阅读:
    C/C++ 链接汇总
    C# 网页操作
    Win10屏幕开始菜单图标丢失修复方案无意中发现的...
    AI 人工智能
    GIT 命令
    Layui / WEB UI
    PHP DES解密 对应Java SHA1PRNG方式加密
    视频参数介绍及关系《转》
    分布式时系统/服务 数据一致性方案
    JS埋点 小结
  • 原文地址:https://www.cnblogs.com/vb4896/p/3982069.html
Copyright © 2011-2022 走看看