当前位置: 首页 > news >正文

网站分析工具做进口零食网站

网站分析工具,做进口零食网站,优秀的app交互界面设计,一件代发海外电商平台目录 1. 整数转罗马数字 2. 跳跃游戏 II 3. 买卖股票的最佳时机 IV 1. 整数转罗马数字 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。 字符 数值 I 1 V 5 X …

目录

1. 整数转罗马数字

2. 跳跃游戏 II

3. 买卖股票的最佳时机 IV


1. 整数转罗马数字

罗马数字包含以下七种字符: I, V, X, LCD 和 M

字符          数值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000

例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做  XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

  • I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
  • X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。 
  • C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。

给你一个整数,将其转为罗马数字。

示例 1:

输入: num = 3输出: "III"

示例 2:

输入: num = 4输出: "IV"

示例 3:

输入: num = 9输出: "IX"

示例 4:

输入: num = 58输出: "LVIII"解释: L = 50, V = 5, III = 3.

示例 5:

输入: num = 1994输出: "MCMXCIV"解释: M = 1000, CM = 900, XC = 90, IV = 4.

提示:

  • 1 <= num <= 3999

代码:

#include <stdio.h>
#include <string.h>char result[64];
struct rmap
{const char *r;int v;
} units[] = {{"M", 1000},{"CM", 900},{"D", 500},{"CD", 400},{"C", 100},{"XC", 90},{"L", 50},{"XL", 40},{"X", 10},{"IX", 9},{"V", 5},{"IV", 4},{"I", 1}};char *intToRoman(int num)
{result[0] = 0;int ri = 0;int i = 0;while (num){if (num >= units[i].v){strcat(result, units[i].r);num -= units[i].v;}else{i++;}}return result;
}int main()
{int num;printf("num = ");scanf("%d", &num);printf("%s", intToRoman(num));return 0;
}

输出:

num = 3
III

-------------------

num = 4
IV

-------------------

num = 9
IX

-------------------

num = 58
LVIII

-------------------

num = 1994
MCMXCIV

2. 跳跃游戏 II

给定一个非负整数数组,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

示例:

输入: [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。

说明:

假设你总是可以到达数组的最后一个位置。

代码:

#include <bits/stdc++.h>
using namespace std;class Solution
{
public:int jump(vector<int> &nums){int steps = 0;int lo = 0, hi = 0;while (hi < nums.size() - 1){int right = 0;for (int i = lo; i <= hi; i++){right = max(i + nums[i], right);}lo = hi + 1;hi = right;steps++;}return steps;}
};int main()
{vector <int> vect = {2,3,1,1,4};Solution s;cout << s.jump(vect) <<endl;return 0;
}

代码2:

#include <bits/stdc++.h>
using namespace std;class Solution {
public:int jump(vector<int>& nums) {int i = 0, j = 1, steps = 0, n = nums.size();while(j < n){int end = min(nums[i] + i + 1, n);while(j < end){if(nums[j] + j > nums[i] + i)  i = j;j++;}steps++;}return steps;}
};int main()
{vector <int> vect = {2,3,1,1,4};Solution s;cout << s.jump(vect) <<endl;return 0;
}

代码3:

#include <bits/stdc++.h>
using namespace std;class Solution {
public:int jump(vector<int>& nums) {int maxPos = 0, n = nums.size(), end = 0, step = 0;for (int i = 0; i < n - 1; ++i) {if (maxPos >= i) {maxPos = max(maxPos, i + nums[i]);if (i == end) {end = maxPos;++step;}}}return step;}
};int main()
{vector <int> vect = {2,3,1,1,4};Solution s;cout << s.jump(vect) <<endl;return 0;
}

3. 买卖股票的最佳时机 IV

给定一个整数数组 prices ,它的第 i 个元素 prices[i] 是一支给定的股票在第 i 天的价格。

设计一个算法来计算你所能获取的最大利润。你最多可以完成 k 笔交易。

注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

示例 1:

输入:k = 2, prices = [2,4,1]
输出:2
解释:在第 1 天 (股票价格 = 2) 的时候买入,在第 2 天 (股票价格 = 4) 的时候卖出,这笔交易所能获得利润 = 4-2 = 2 。

示例 2:

输入:k = 2, prices = [3,2,6,5,0,3]
输出:7
解释:在第 2 天 (股票价格 = 2) 的时候买入,在第 3 天 (股票价格 = 6) 的时候卖出, 这笔交易所能获得利润 = 6-2 = 4 。
随后,在第 5 天 (股票价格 = 0) 的时候买入,在第 6 天 (股票价格 = 3) 的时候卖出, 这笔交易所能获得利润 = 3-0 = 3 。

提示:

  • 0 <= k <= 100
  • 0 <= prices.length <= 1000
  • 0 <= prices[i] <= 1000
#include <bits/stdc++.h>
using namespace std;class Solution
{
public:int maxProfit(int k, vector<int> &prices){const int len = prices.size();if (len <= 1 || k == 0)return 0;if (k > len / 2)k = len / 2;const int count = k;int buy[count];int sell[count];for (int i = 0; i < count; ++i){buy[i] = -prices[0];sell[i] = 0;}for (int i = 1; i < len; ++i){buy[0] = max(buy[0], -prices[i]);sell[0] = max(sell[0], buy[0] + prices[i]);for (int j = count - 1; j > 0; --j){buy[j] = max(buy[j], sell[j - 1] - prices[i]);sell[j] = max(buy[j] + prices[i], sell[j]);}}return sell[count - 1];}
};int main()
{vector <int> vect = {3,2,6,5,0,3};int k = 2;Solution s;cout << s.maxProfit(k, vect) <<endl;return 0;
}

http://www.yayakq.cn/news/15033/

相关文章:

  • vs网站开发参考文献合肥百度网站排名优化
  • 广州网站开发债券交专业律所网站建设
  • 辽宁住房和建设厅网站制作书签的方法和步骤
  • 建立可以在线做照片的网站北京出啥大事了今天
  • 怎么做各类网站电子商务网站建设 教案
  • 有产品做推广,选哪个 网站上海制作网页的公司有哪些
  • 什么企业做网站网站设置评价
  • 洞头网站建设网站建设销售怎么样
  • zhongwen网站模板好消息tvapp电视版
  • 北京建设监理网站网站建设时送的ppt方案
  • 湖南建设人力资源湖南网站建设石家庄小学网站建设
  • 广州网站建设定制设计东莞智通人才招聘网官网
  • 网站目标关键词a4网站建设
  • 做号网站wordpress 添加媒体库
  • 做网站关键词必须要中文网址空港经济区内的建设工程网站
  • ui设计和网站建设人员李伟宁重庆招投标综合信息网
  • 营销型网站策划 建设的考试题公众号微网站建设认证
  • 34线城市做网站推广网站建设完工确认书
  • 订货网站怎么做wordpress页面添加图片
  • 做网站在线酒店网站建设论文
  • 高端网站设计 必荐骏网添城科技河北邯郸特色美食
  • 网页设计后面是网站建设吗南京网站设计我选柚米科技
  • 建设网站前的市场分析show-useragent wordpress 不显示
  • 西安网站建设是什么微信小程序怎么申请
  • 电子商务网站设计是什么建设网站需要的资料
  • 开一个网站建设公司好深圳网页网站设计
  • 深圳南园网站建设哪个网站可以做房产信息群发
  • 有专做高端折扣女装的网站吗兴平住房和城乡建设局门户网站
  • 南通个人网站制作idc销售网站php源代码
  • 怎么看网站的服务器wordpress恶意代码在线检测