投资策略规划最优决策分析
目录
一、投资策略规划问题详细
二、存在最优投资策略:每年都将所有钱投入到单一投资产品中
(一)状态转移方程
(二)初始条件与最优策略
(三)证明最优策略总是将所有钱投入到单一投资产品中
三、证明:规划最优投资策略问题具有最优子结构性质
(一)问题描述和基本假设
(二)直观证明
四、设计最优投资策略规划算法并分析时间复杂度
(一)问题回顾
(二)算法设计步骤
定义状态和状态转移
初始化与迭代计算
终止条件判定
(三)实际验证
(四)时间复杂度分析
五、新限制条款证明:最大化10年回报问题不再具有最优子结构性质
(一)最优子结构性质
(二)问题描述和限制条件
(三)反例证明不再具有最优子结构性质
六、总结
干货分享,感谢您的阅读!
投资决策是金融领域中极具挑战性和复杂性的问题之一。如何在多变的市场环境中制定最优投资策略,以实现长期的最大化回报,是每个投资者关心的核心问题。
一、投资策略规划问题详细
你所掌握的算法知识帮助你从Acme计算机公司获得了一份令人兴奋的工作,签约奖金1万美元。你决定利用这笔钱进行投资,目标是10年后获得最大回报。你决定请Amalgamated投资公司管理你的投资,该公司的投资回报规则如下:
该公司提供 n 种不同的投资产品,从 1~n 编号。在第 j 年,第 i 种投资产品的回报率为。换句话说,如果你在第 j 年在第 i 种投资产品投入 d 美元,那么在第 j 年年底,你会得到美元。回报率是有保证的,即未来10年每种投资产品的回报率均已知。你每年只能做出一次投资决定。在每年年底,你既可以将钱继续投入到上一年选择的投资产品中,也可以转移到其他投资产品中(转移到已有的投资产品,或者新的投资产品)。如果跨年时你不做投资转移,需要支付美元的费用。否则,需要支付美元的费用,其中。
a. 如上所述,本问题允许你每年将钱投入到多种投资产品中。证明:存在最优投资策略,每年都将所有钱投入到单一投资产品中(记住最优投资策略只需最大化10年的回报,无需关心任何其他目标,如最小化风险)。
b. 证明:规划最优投资策略问题具有最优子结构性质。
c. 设计最优投资策略规划算法,分析算法时间复杂度。
d. 假定Amalgamated投资公司在上述规则上又加入了新的限制条款,在任何时刻你都不能在任何单一投资产品中投入15000美元以上。证明:最大化10年回报问题不再具有最优子结构性质。
二、存在最优投资策略:每年都将所有钱投入到单一投资产品中
这个问题可以通过动态规划来解决。我们首先定义一个状态表示,以便在每个决策点上找到最优的投资策略。
假设我们定义 dp[i][j] 表示在第 i 年选择第 j 种投资产品所能获得的最大回报。我们需要递归地计算这些状态,并考虑到不同投资产品之间的转移费用。
(一)状态转移方程
为了计算 dp[i][j] ,我们需要考虑两种情况:
- 继续投资于同一个产品。
- 转移投资到不同的产品。
因此,我们有:
其中:
- 是第 i−1 年第 k 种投资产品的回报率。
- 是第 i 年第 j 种投资产品的回报率。
- 是不做投资转移的费用。
- 是进行投资转移的费用。
(二)初始条件与最优策略
对于初始年份,我们假设初始投入金额为 d:
通过上述状态转移方程,我们可以构建一个 dp 数组,并逐步填充每一年的最优投资策略。最终的答案是:
(三)证明最优策略总是将所有钱投入到单一投资产品中
为了证明存在最优策略每年将所有钱投入到单一投资产品中,我们注意到:
- 在每个时间点上,我们通过动态规划的状态转移方程求得了每一年中每个投资产品的最优决策。
- 如果存在一种最优策略每年将钱分散到多个投资产品,那么这些策略的收益可以通过组合这些投资产品的单一投资策略来模拟。因此,总存在一种单一投资策略与分散投资策略具有相同或更高的回报。
- 因此,通过动态规划找到的最优策略,本质上每年都会选择一个最优的单一投资产品来最大化回报。
综上所述,基于动态规划求解,我们总能找到每年投入单一投资产品的最优策略,从而最大化10年的总回报。
三、证明:规划最优投资策略问题具有最优子结构性质
(一)问题描述和基本假设
我们有 n 种投资产品,每种产品在每年的回报率为 。我们每年只能选择一种产品进行投资,并且在转换投资产品时需要支付不同的费用 (不转换)和 (转换)。
最优子结构性质意味着,一个问题的最优解包含其子问题的最优解。
(二)直观证明
我们从最优解的角度出发,考虑最后一年的投资决策,然后向前推导每一年的投资决策。
假设在第 10 年,我们的投资产品选择是最优的。如果我们选择在第 10 年投资产品 j,这意味着从第 9 年到第 10 年的投资决策也是最优的。
假设在第 9 年,我们选择了投资产品 i,并在第 10 年转移到投资产品 j。那么,最优策略必须保证第 9 年的投资产品 i 是在第 8 年的最优决策基础上选择的。
我们考虑第 8 年的投资决策,如果第 9 年投资产品 i 是最优的,那么第 8 年的投资决策也是在所有可能的投资产品中选择的最优方案。
我们可以递归地推导到第 1 年,保证每年的投资决策都是基于前一年最优选择的结果。
假设有 3 种投资产品(A、B、C),每年的回报率如下:
年份 | A | B | C |
---|---|---|---|
1 | 1.1 | 1.2 | 1.3 |
2 | 1.3 | 1.1 | 1.2 |
3 | 1.2 | 1.3 | 1.1 |
费用 (不转换),(转换)。
假设我们在第 3 年选择了投资产品 B,并且这是最优选择。我们需要保证从第 2 年到第 3 年的决策也是最优的。
假设在第 2 年,我们选择了投资产品 A,然后在第 3 年转移到投资产品 B。此时我们有:
其中 X 是第 1 年的投资产品,f 是费用。
我们可以继续推导第 1 年的决策,保证第 1 年的选择也是基于最优结果的。
通过上述递归推导和具体示例,我们可以直观地看到:
- 每年的最优投资决策是基于前一年的最优决策。
- 如果最后一年的投资决策是最优的,那么前一年的投资决策也是最优的,递归到第一年。
上述过程证明了,最优投资策略问题具有最优子结构性质:即一个问题的最优解包含其子问题的最优解。这一性质使得我们可以使用动态规划方法来求解该问题,保证整体最优解的正确性和有效性。
四、设计最优投资策略规划算法并分析时间复杂度
(一)问题回顾
我们有 n 种投资产品,每种产品在每年的回报率是已知的。初始投资金额为 10,000 美元。目标是在 10 年后获得最大回报。每年可以选择将资金投入到当前的产品或转移到其他产品。转移资金时有费用 (不转换)和 (转换)。
(二)算法设计步骤
定义状态和状态转移
动态规划的核心思想是将复杂问题分解为更小的子问题,并通过解决这些子问题构建最终解。
状态定义:用 dp[i][j]
表示在第 i
年选择第 j
种投资产品所能获得的最大回报。
状态转移方程:每年我们有两种选择:继续投资于同一个产品,或者转移到另一个产品。
如果继续投资于同一个产品:
如果转移到另一个产品:
初始化与迭代计算
初始投资金额为 initialInvestment
。第一年将资金投入到所有可能的产品中,并计算初始回报。 则:
迭代计算
- 对于每一年
i
(从第 1 年到第 10 年),我们计算每个产品j
的最大回报。 - 对于每个产品
j
,我们需要比较继续投资和转移投资的情况,并取最大值。
终止条件判定
在第 10 年结束时,取所有产品中的最大回报值作为最终结果。
(三)实际验证
我们假设有 3 种投资产品(A、B、C),回报率矩阵如下:
费用 f1 = 50
,f2 = 100
。初始投资金额 initialInvestment = 10000
。我们按照之前的思路来实现代码如下:
package org.zyf.javabasic.letcode.dynamicprogramming.project;/*** @program: zyfboot-javabasic* @description: 动态规划算法来解决最优投资策略问题* @author: zhangyanfeng* @create: 2021-09-25 23:00**/
public class InvestmentStrategy {// 计算最大回报的方法public static double maxReturn(int years, int products, double initialInvestment, double[][] r, double f1, double f2) {double[][] dp = new double[years + 1][products];// 初始化:第一年各产品的投资回报for (int j = 0; j < products; j++) {dp[0][j] = initialInvestment * r[j][0];}// 状态转移for (int i = 1; i <= years; i++) {for (int j = 0; j < products; j++) {// 假设继续投资当前产品dp[i][j] = dp[i-1][j] * r[j][i] - f1;// 考虑转移到其他产品for (int k = 0; k < products; k++) {if (k != j) {dp[i][j] = Math.max(dp[i][j], dp[i-1][k] * r[j][i] - f2);}}}}// 获取最终最大值double maxReturn = 0;for (int j = 0; j < products; j++) {maxReturn = Math.max(maxReturn, dp[years][j]);}return maxReturn;}public static void main(String[] args) {int years = 10;int products = 3;double initialInvestment = 10000;double[][] r = {{1.1, 1.2, 1.3, 1.1, 1.3, 1.2, 1.1, 1.3, 1.2, 1.1, 1.3},{1.3, 1.1, 1.2, 1.3, 1.1, 1.2, 1.3, 1.1, 1.2, 1.3, 1.1},{1.2, 1.3, 1.1, 1.2, 1.3, 1.1, 1.2, 1.3, 1.1, 1.2, 1.3}};double f1 = 50;double f2 = 100;System.out.println("最大回报: " + maxReturn(years, products, initialInvestment, r, f1, f2));}
}
运行结果为:
最大回报: 149207.90551039999
(四)时间复杂度分析
初始化:初始化 dp
数组的时间复杂度是 O(n),其中 n 是产品数量。
状态转移:每年对每个产品计算最优值需要比较所有可能的产品组合。对于第 i
年的第 j
种产品,最多需要遍历前一年所有 k
种产品。因此,状态转移的时间复杂度是 ,其中 m 是年数,n 是产品数量。
最终解:找到最后一年的最大值需要 O(n)。
所以,总的算法的时间复杂度为 。
通过上述步骤,我们设计并实现了一个动态规划算法来解决最优投资策略问题。该算法基于状态转移和最优子结构的原理,通过递归计算每年的最优投资选择,最终得到最大回报。时间复杂度为 ,适用于一般规模的投资问题。
五、新限制条款证明:最大化10年回报问题不再具有最优子结构性质
假定Amalgamated投资公司在上述规则上又加入了新的限制条款,在任何时刻你都不能在任何单一投资产品中投入15000美元以上。证明:最大化10年回报问题不再具有最优子结构性质。
为了证明最大化10年回报问题在加入每个投资产品的投资金额不能超过15000美元的限制后,不再具有最优子结构性质,我们需要明确什么是最优子结构性质。
(一)最优子结构性质
最优子结构性质(Optimal Substructure Property)是指一个问题的最优解可以由其子问题的最优解构建而成。具体到动态规划问题上,就是说如果我们知道如何解决子问题,那么我们就可以利用这些子问题的解来构建出原问题的解。
(二)问题描述和限制条件
在原问题中,我们每年可以选择将资金继续投入到当前的产品或转移到其他产品,且每次转移都有一定的费用。在这种情况下,问题具有最优子结构性质,因为每一年的决策只依赖于前一年各个产品的最优决策。
然而,当加入了每个投资产品的投资金额不能超过15000美元的限制后,情况变得复杂:我们在每年的决策中不仅要考虑前一年的回报,还要考虑当前投资产品的投资金额是否已经达到了15000美元的上限。
(三)反例证明不再具有最优子结构性质
假设我们有3种投资产品,分别为A、B、C,初始投资金额为10000美元,每年的回报率如下:
转移费用分别为f1 = 50,f2 = 100。假设我们在任何单一投资产品中的投资金额不能超过15000美元。
第一年:
- 投资产品A:10000 * 1.5 = 15000
- 投资产品B:10000 * 1.2 = 12000
- 投资产品C:10000 * 1.1 = 11000
第二年:
- 如果第一年投资在产品A中,已经达到15000美元上限,第二年无法继续投资在A中,只能转移到B或C。
- 如果第一年投资在产品B中,第二年继续投资在B中:12000 * 1.3 = 15600(超过15000美元),所以只能转移到其他产品,但投资在A中会因15000美元限制受到影响。
通过上面的例子我们可以看到,在存在投资金额上限的情况下,每年的最优决策不仅依赖于前一年的回报率,还依赖于当前的投资金额是否达到了上限。因此,我们不能简单地通过前一年各个产品的最优决策来构建当前年的最优决策。
由于每年的决策需要考虑当前投资产品的投资金额是否已经达到15000美元的上限,这种限制引入了额外的复杂性,使得当前年的最优决策不仅依赖于前一年的回报率,还依赖于投资金额是否达到上限。因此,问题不再具有最优子结构性质。这意味着,我们无法简单地通过前一年各个产品的最优决策来构建当前年的最优决策,从而使得使用动态规划的方法变得更加复杂甚至不可行。
六、总结
我们从一个简单而经典的投资问题出发,假设每年只能在多种投资产品中做出一次投资决策,并分析在给定回报率和转移费用的情况下,如何制定最优的10年投资策略。在初步的分析中,我们假设每种投资产品的回报率是确定且已知的,通过数学证明和算法设计,得出每年将所有资金投入到单一投资产品中的最优策略。
接下来,我们进一步证明了该问题具有最优子结构性质,这是动态规划解决方案的基础。然而,当我们引入了现实中常见的投资限制条件——任何单一投资产品的投资金额不能超过15000美元时,问题的性质发生了变化。我们通过反例证明了在这种限制条件下,问题不再具有最优子结构性质,从而对传统动态规划方法提出了挑战。
相关文章:
投资策略规划最优决策分析
目录 一、投资策略规划问题详细 二、存在最优投资策略:每年都将所有钱投入到单一投资产品中 (一)状态转移方程 (二)初始条件与最优策略 (三)证明最优策略总是将所有钱投入到单一投资产品中…...
一篇保姆式虚拟机安装ubantu教程
前言: 本文将介绍在VMware安装ubantu,会的人可以试试上一篇介绍centos/ubantu安装docker环境,不同环境安装docker。一篇保姆式centos/unbantu安装docker 官网下载iso:Ubuntu 18.04.6 LTS (Bionic Beaver) 本次使用的版本是: 一&…...
缓冲区的奥秘:解析数据交错的魔法
目录 一、理解缓存区的好处 (一)直观性的理解 (二)缓存区的好处 二、经典案例分析体会 (一)文件读写流(File I/O Buffering) BufferedOutputStream 和 BufferedWriter 可以加快…...
CentOS 7.9 搭建本地Yum源
yum(Yellow Dog Updater,Modified)是一个在Fedora、Centos、RedHat中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖关系,并且一次安装所有依赖的软件…...
【Python】爬虫实战:高效爬取电影网站信息指南(涵盖了诸多学习内容)
本期目录 1 爬取思路 2 爬虫过程 2.1 网址 2.2 查看网页代码 3 爬取数据 3.1 导入包 3.2 爬取代码 01 爬取思路 \*- 第一步,获取页面内容\*- 第二步:解析并获取单个项目链接 \*- 第三步:获取子页面内容 \*- 第四步:解析…...
MATLAB和C++及Python流式细胞术
🌵MATLAB 片段 流式细胞术(Flow Cytometry)是一种用于分析细胞或其他颗粒悬浮在流动介质中的方法。MATLAB 可以用来处理和分析流式细胞术的数据,例如用于数据预处理、可视化和分析。以下是一些常见的 MATLAB 处理流式细胞术数据的…...
Vue3 pinia使用
Pinia 是一个现代的状态管理库,专为 Vue 3 设计。它提供了一种简单、直观的方式来管理应用中的全局状态 (就是不同组件都希望去共享的一些变量,函数等)。Pinia 的设计灵感来自于 Vuex(Vue 2 的状态管理库),但进行了许多改进&#…...
tdengine学习笔记-建库和建表
目录 建库和建表 创建超级表 创建表 自动建表 创建普通表 多列模型 VS 单列模型 数据类型映射 示例程序汇总 在车联网领域的应用 1. 数据模型概述 2. 表结构设计 2.1 静态数据表 2.2 动态数据表 4. 查询数据 4.1 查询单个车辆的数据 4.2 查询多个…...
Django数据迁移出错,解决raise NodeNotFoundError问题
错误出现在: raise NodeNotFoundError(self.error_message, self.key, originself.origin) django.db.migrations.exceptions.NodeNotFoundError: Migration myApp.0003_alter_jobinfo_practise dependencies reference nonexistent parent node (myApp, 0002_renam…...
景联文科技:以全面数据处理服务推动AI创新与产业智能化转型
数据标注公司在人工智能领域扮演着重要角色,通过提供高质量的数据标注服务,帮助企业和组织训练和优化机器学习模型。从需求分析到数据交付,每一个步骤都需要严格把控,确保数据的质量和安全性。 景联文科技是一家专业的数据采集与标…...
MySQL学习/复习7表的内外连接
一、内连接...
Spring Cloud入门笔记2(OpenFeign)
场景: OpenFeign中集成了LoadBalancer,并简化了微服务调用,所以实际上使用该技术 技术栈:OpenFeign 步骤一:导入依赖 <!--openfeign--> <dependency><groupId>org.springframework.cloud</groupId><a…...
小程序中模拟发信息输入框,让textarea可以设置最大宽以及根据输入的内容自动变高的方式
<textarea show-confirm-bar"{{false}}" value"{{item.aValue}}" maxlength"301" placeholder"请输入" auto-height"{{true}}" bind:blur"onBlurTextarea" focus"{{true}}" bindinput"…...
学习HTML第二十九天
学习文章目录 二.单选框三.复选框 二.单选框 常用属性如下: name 属性:数据的名称,注意:想要单选效果,多个 radio 的 name 属性值要保持一致。 value 属性:提交的数据值。 checked 属性:让该单…...
汽车安全再进化 - SemiDrive X9HP 与环景影像系统 AVM 的系统整合
当今汽车工业正面临著前所未有的挑战与机遇,随著自动驾驶技术的迅速发展,汽车的安全性与性能需求日益提高。在这样的背景下,汽车 AVM(Automotive Visual Monitoring)标准应运而生,成为促进汽车智能化和安全…...
QString 转 char*问题与方法(const_cast的使用问题)
1、背景:今天有QString的变量,将QString的值传递给void func(char * ptr),于是就有了类似下面这一段离谱的代码 当时我还在想为什么var的值为空了,为什么呢。 2、原因:就是因为右边函数返回的是一个临时指针对象,给到了右边&…...
flink cdc 应用
SQLServer 1. The db history topic or its content is fully or partially missing. Please check database history topic configuration and re-execute the snapshot. 遇到了一下问题,多次尝试,最终发现是数据库大小写要一致。 Caused by: io.deb…...
MyBlog(三) -- APP的应用
文章目录 前言一、APP是什么?二、创建APP三、使用APP1. 注册app2. 添加路由3. 运行过程4. 完善视图函数5. 结果展示 总结 前言 前面我们已经学习了如何创建一个新的项目,并且配置好了项目的启动文件,成功将项目启动! 那么接下来我们的主要任务就是需要完善这个项目中应该包含…...
docker有哪些网络模式
Docker 提供了多种网络模式(Networking Modes),每种模式都有其特定的用例和优缺点。以下是 Docker 的几种主要网络模式: 1. Bridge 网络(默认) 描述:在这种模式下,Docker 创建了一…...
npoi 如何设置单元格为文本类型
ICellStyle style workbook.CreateCellStyle(); var font workbook.CreateFont(); font.FontHeightInPoints 10; //font.FontName "Arial"; font.FontName "仿宋"; style.Alignment NP…...
Vue3、Vite5、Primevue、Oxlint、Husky9 简单快速搭建最新的Web项目模板
Vue3、Vite5、Oxlint、Husky9 简单搭建最新的Web项目模板 特色进入正题创建基础模板配置API自动化导入配置组件自动化导入配置UnoCss接入Primevue接入VueRouter4配置项目全局环境变量 封装Axios接入Pinia状态管理接入Prerttier OXLint ESLint接入 husky lint-staged…...
DataStream编程模型之数据源、数据转换、数据输出
Flink之DataStream数据源、数据转换、数据输出(scala) 0.前言–数据源 在进行数据转换之前,需要进行数据读取。 数据读取分为4大部分: (1)内置数据源; 又分为文件数据源; socket…...
海康IPC接入TRTC时,从海康中获取的数据显示时色差不正确
2021/1 记录海康IPC接入TRTC时的历史日志 从海康sdk接口获取数据,进行解码 org.MediaPlayer.PlayM4.Player.T_YV12;private void setDecodeCB() {Player.getInstance().setDecodeCB(m_iPort, (nPort, data, nDataLen, nWidth, nHeight, nFrameTime, nDataType,…...
『VUE』31. 生命周期的应用(详细图文注释)
目录 在合适的时间进行操作取dom元素利用生命周期模拟网络数据发送代码示例 总结 欢迎关注 『VUE』 专栏,持续更新中 欢迎关注 『VUE』 专栏,持续更新中 在合适的时间进行操作 假设网页一颗果树,我们要取dom(果实),一定要在渲染完成后才能取(果实) 通常…...
Mybatis框架之建造者模式 (Builder Pattern)
MyBatis 框架中大量使用了 建造者模式 (Builder Pattern) 来构建复杂的对象,尤其是在 SQL 语句的解析、配置对象的创建以及动态 SQL 的生成 等方面。建造者模式使得 MyBatis 能够更灵活、清晰地构建对象,尤其是那些需要多步创建和配置的复杂对象。 1. 什…...
Java从入门到精通笔记篇(十三)
与流处理 ambda表达式 定义 lambda表达式不能被独立执行,因此必须实现函数式接口,并且会返回一个函数式接口的对象。 可将其语法用下列的方式理解 误区警示 “->”符号是由英文状态下的“-”和“>”组成的,符号之间没有空格。 lambd…...
嵌入式:STM32的启动(Startup)文件解析
相关阅读 嵌入式https://blog.csdn.net/weixin_45791458/category_12768532.html?spm1001.2014.3001.5482 启动文件(Startup File)是嵌入式系统开发中的核心组件之一,它用于初始化系统并为主程序的运行做好准备。在大多数情况下,启动文件是用汇编语言编…...
ElasticSearch学习笔记四:基础操作(二)
一、前言 上一篇文章中我们学习了ES中的基础操作,包括索引和映射,同时也学习了ES中的基础数据类型,今天我们继续学习其他的数据类型。 二、复杂数据类型 1、数组(Array) 在ES中没有特别指定数据类型,换…...
ODA-em-application.log太大处理
检查oda时发现u01使用率很高,层层排查到是em-application.log文件太大 orcl2:/u01/app/oracle/product/11.2.0.4/dbhome_1/oc4j/j2ee/OC4J_DBConsole_oda1_orcl/logoda1>du -sh * 57G em-application.log 2.2M global-application.log 92M …...
基于现金红包营销活动的开源 AI 智能名片与 S2B2C 商城小程序融合发展研究
摘要:本文深入剖析现金红包这一平台补贴的营销利器在消费场景中的多元应用,并将其与开源 AI 智能名片、S2B2C 商城小程序相融合,探讨其中蕴含的创新模式与商业价值。通过详尽解析各类现金红包的使用条件,阐述如何巧妙运用这些营销…...
给公司做网站需要华多少钱/我为什么不建议年轻人做运营
一,题目:输入两个整数序列。其中一个序列表示栈的push顺序,判断另一个序列有没有可能是对应的pop顺序。 如果我们希望pop的数字正好是栈顶数字,直接pop出栈即可; 如果希望pop的数字目前不在栈顶,我们就到pu…...
网上学习做网站/今日头条新闻最新消息
C语言程序设计14985.doc???《 C语言程序设计》实? 训 指? 导? 书??编写人:吴瑞芝?? ????内蒙古化工职业学院计算机与信息工程系2003年??5? 月 8 日????编 写 说 明1、本实训指导书根据计算机类专业教学计划和《C语言程序设计》实训教学大纲编写。2、本实训…...
公司网站建设费怎么写分录/网络舆情分析
一.查询开放的端口 1.查询开放的端口 netstat -antp 2.查询xx端口是否开放 netstat -antp|grep 3306 二.命令形式开放指定端口 1. 开放端口命令: /sbin/iptables -I INPUT -p tcp --dport 8080 -j ACCEPT 2.保存:/etc/rc.d/init.d/ipt…...
网站图片不是本站的对seo有什么不好/上海做网站优化
用:target伪类实现Tab切换效果真的非常简单!简单到什么程度呢?它只需要下面这些代码。 style.css: .song-info {position: absolute;background: #fff; }#song-info:target, #song-lyricCN:target, #song-lyricEN:target {z-inde…...
现在哪个网站可以做外贸/关键词指数
前言 互联网时代的到来,让我们获取知识变得更加简单,理论上讲只要你想学,便会有不尽的知识等你,只要方法得当,够努力,任何人都可以都有可能成为大牛。 自己在努力的基础上,还学习了一些高效的…...
做资讯网站要什么手续/营销型网站建设推广
好的,以下是一个简单的商品选择程序的 C 语言代码示例: #include <stdio.h>int main() {int choice;printf("请选择您想购买的商品:\n");printf("1. 咖啡\n");printf("2. 茶\n");printf("3. 汽水\n");printf("请输入您的…...