亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

greedy: 55. Jump Game / 455. Assign Cookies

2019-11-11 03:10:01
字體:
來源:轉載
供稿:網友

Jump Game題目描述代碼實現Assign Cookies題目描述代碼實現

55. Jump Game

題目描述

Given an array of non-negative integers, you are initially positioned at the first index of the array. Each element in the array rePResents your maximum jump length at that position. Determine if you are able to reach the last index. For example: A = [2,3,1,1,4], return true. A = [3,2,1,0,4], return false.

代碼實現

法一:

// 復雜度O(n^2)的做法,導致超時了。class Solution {public: bool canJump(vector<int>& nums) { int nums_len = nums.size() - 1; vector<bool> flag(nums_len, false); int stt = 0; int jmp = 0; flag[0] = true; cout << nums_len << endl; for(stt = 0; stt <= nums_len; stt++) { if(flag[stt]) { int tmp = nums[stt] + stt; for(int in_range = tmp; in_range >= stt; in_range--) { if(in_range >= nums_len) return true; flag[in_range] = true; // cout << in_range << " " << flag[in_range] << " " << stt << endl; } } } return false; }};

法二: 修改第二個進入循環的條件,沒有必要重復設置可以跳轉的標志位。這樣做了以后可以擊敗95%的c++代碼。

class Solution {public: bool canJump(vector<int>& nums) { int nums_len = nums.size() - 1; vector<bool> flag(nums_len, false); int stt = 0; int jmp = 0; int out_range = -1; flag[0] = true; cout << nums_len << endl; for(stt = 0; stt <= nums_len; stt++) { if(flag[stt]) { int tmp = nums[stt] + stt; if(tmp > out_range) { for(int in_range = tmp; in_range > out_range; in_range--) { if(in_range >= nums_len) return true; flag[in_range] = true; // cout << in_range << " " << flag[in_range] << " " << stt << endl; } out_range = tmp; } } } return false; }};

把上面的代碼做些簡化設計,可以得到:

class Solution {public: bool canJump(vector<int>& nums) { int nums_len = nums.size(); int i = 0, maxreach = 0; for (; i < nums_len && i <= maxreach && maxreach < nums_len - 1; ++i) maxreach = max(maxreach,i+nums[i]); return maxreach>=nums_len-1; }};

這種做法比較簡約,但是效率比較低。因為它需要對所有的情況調用max函數,遇到較大的數組的時候就會比較耗時。這種做法不如我在法二中做的剪枝那么有效。

455. Assign Cookies

題目描述

Assume you are an awesome parent and want to give your children some cookies. But, you should give each child at most one cookie. Each child i has a greed factor gi, which is the minimum size of a cookie that the child will be content with; and each cookie j has a size sj. If sj >= gi, we can assign the cookie j to the child i, and the child i will be content. Your goal is to maximize the number of your content children and output the maximum number. Note: You may assume the greed factor is always positive. You cannot assign more than one cookie to one child. Example 1: Input: [1,2,3], [1,1] Output: 1 Explanation: You have 3 children and 2 cookies. The greed factors of 3 children are 1, 2, 3. And even though you have 2 cookies, since their size is both 1, you could only make the child whose greed factor is 1 content. You need to output 1. Example 2: Input: [1,2], [1,2,3] Output: 2 Explanation: You have 2 children and 3 cookies. The greed factors of 2 children are 1, 2. You have 3 cookies and their sizes are big enough to gratify all of the children, You need to output 2.

代碼實現

這種做法擊敗了99.24%的做法,思路比較簡單。就是先排序在比較。比較的時候,如果比較到s的索引為s_stt,s_stt之前的都沒有必要在下一次比較。

class Solution {public: int findContentChildren(vector<int>& g, vector<int>& s) { int content_num = 0; int g_len = g.size(); int s_len = s.size(); sort(g.begin(), g.end()); sort(s.begin(), s.end()); int s_stt = 0; for(int i = 0; i < g_len; i++) { for(int j = s_stt; j < s_len; j++) { if(g[i] <= s[j]) { content_num++; s_stt = j+1; break; } } } return content_num; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91国自产精品中文字幕亚洲| 欧美另类99xxxxx| 国产亚洲精品va在线观看| 久久理论片午夜琪琪电影网| 国产精品自拍网| 国产精品夜色7777狼人| 日本高清不卡在线| 国产成人在线一区二区| 欧美中文字幕视频在线观看| 日韩av免费看| 欧美激情亚洲精品| 亚洲图片欧美日产| 国产精品入口免费视频一| 欧美天天综合色影久久精品| 日韩av电影在线免费播放| 国产黑人绿帽在线第一区| 成人激情综合网| 91在线高清免费观看| 69久久夜色精品国产69| 欧美一级在线亚洲天堂| 日韩精品中文字幕在线观看| 亚洲男人av电影| 91av视频在线| 国产亚洲精品久久久久久777| 国产欧美一区二区| 久久夜色撩人精品| 国产精品第一视频| 久久在精品线影院精品国产| 欧美一级在线播放| 性视频1819p久久| 日韩av一区二区在线观看| 午夜精品久久久99热福利| 久久久久久欧美| 日韩电影视频免费| 久久免费成人精品视频| 欧洲一区二区视频| 日韩av理论片| 欧美中文在线观看| 国产91精品高潮白浆喷水| 亚洲国产精品福利| 国产精品久久不能| 久久久久久久久久久免费精品| 国产一区二区三区高清在线观看| 欧美成人激情在线| 日韩免费电影在线观看| 亚洲欧美三级伦理| 亚洲一区二区三区四区视频| 国产va免费精品高清在线| 欧美日韩中文字幕综合视频| 中文字幕在线视频日韩| 4388成人网| 欧美一级在线播放| 亚洲日韩欧美视频| 日韩精品一区二区视频| 欧美在线视频观看| www亚洲欧美| 欧洲精品久久久| 91深夜福利视频| 欧美日韩综合视频| 海角国产乱辈乱精品视频| 91av在线不卡| 国产不卡av在线免费观看| 亚洲精品少妇网址| 亚洲电影免费观看高清完整版在线| 中文字幕亚洲无线码a| 欧美性精品220| 奇米影视亚洲狠狠色| 亚洲一区二区在线播放| 欧美夫妻性生活视频| www.xxxx欧美| 日韩精品免费综合视频在线播放| 国产日韩在线一区| 日韩免费av在线| 日韩av日韩在线观看| 欧美日本高清视频| 色综合久久久久久中文网| 欧美巨大黑人极品精男| 亚洲自拍小视频免费观看| 欧美亚洲日本黄色| 在线观看免费高清视频97| 亚洲国产成人久久综合一区| 欧美日韩免费看| 91精品视频观看| 韩国福利视频一区| 亚洲va久久久噜噜噜| 69**夜色精品国产69乱| 日韩欧美福利视频| 国产精品视频男人的天堂| 亚洲人成电影网站色www| 欧洲s码亚洲m码精品一区| 日韩欧美有码在线| 国产精品va在线播放| 国产精品国语对白| 日韩精品视频免费专区在线播放| 亚洲人免费视频| 亚洲国产精品成人av| 午夜精品一区二区三区在线播放| 日韩亚洲第一页| 色阁综合伊人av| 欧美亚洲午夜视频在线观看| 久久免费观看视频| 欧美日韩日本国产| 欧美精品中文字幕一区| 亚洲美女av在线| 亚洲的天堂在线中文字幕| 国产精品香蕉国产| 久久国产加勒比精品无码| 国产成人在线亚洲欧美| 精品美女久久久久久免费| 久久国产色av| 日韩精品在线观看一区二区| 亚洲一级片在线看| 亚洲一区二区三区sesese| 欧美日韩国产影院| 国产欧美精品日韩| 亚洲黄色免费三级| 日本高清久久天堂| 久久精品国产96久久久香蕉| 91香蕉嫩草神马影院在线观看| 欧美日韩在线影院| 国产精品无av码在线观看| 久久高清视频免费| 精品亚洲男同gayvideo网站| 欧美老女人xx| 日本久久久久久| 日韩免费中文字幕| www.欧美三级电影.com| 日韩av免费在线播放| 久久久91精品国产一区不卡| 国产极品jizzhd欧美| 夜夜嗨av一区二区三区免费区| 欧美精品电影免费在线观看| 性色av一区二区三区免费| 亚洲毛片在线观看.| 黑人巨大精品欧美一区免费视频| 亚洲bt天天射| 神马国产精品影院av| 亚洲精品国产综合久久| 精品久久久久久久久久ntr影视| 国产精品av网站| 亚洲欧美一区二区激情| 91国产一区在线| 亚洲综合中文字幕在线观看| 久久免费视频在线| 午夜精品免费视频| 一区二区欧美在线| 国产精品精品久久久久久| 久久人人爽亚洲精品天堂| 欧美中文字幕在线观看| 国产精品私拍pans大尺度在线| 亚洲激情在线观看| 成人激情电影一区二区| 国产盗摄xxxx视频xxx69| 日韩精品中文字幕视频在线| 欧美一级高清免费播放| 亚洲最大的网站| 亚洲精品久久久一区二区三区| 久久视频在线看| 欧美激情视频在线免费观看 欧美视频免费一| 久久视频这里只有精品| 国产成人+综合亚洲+天堂| 亚洲精品国产精品国产自| 91精品视频在线免费观看| 国产精品h片在线播放|