www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > > 充電吧
[導(dǎo)讀]題目鏈接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_

題目鏈接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=5158


題目大意:

??? 敵我雙方,我方n只軍隊,敵方m只軍隊,每只軍隊兩個屬性值,生命值和攻擊力。兩軍交戰(zhàn),本身生命值減去對方的攻擊力。若剩余生命值小于等于0,則犧牲。問我軍能否消滅敵軍,能的話,最多生還多少隊伍,不能的話,輸出-1。


解題:

??? 做的時候,怎么都理不清思路,因為要結(jié)合數(shù)據(jù)結(jié)構(gòu)考慮,始終覺得無法找到合適的數(shù)據(jù)結(jié)構(gòu)。參考了這篇博客,大致思路是這樣的,首要任務(wù)是消滅全部敵軍,次要任務(wù)是保全更多的自己的部隊。先將我方軍隊按攻擊力排序,敵方軍隊按生命值排序。用multiset維護我方軍隊的生命值,只要加入multiset中的軍隊,其攻擊力都是足以消滅敵方的當(dāng)前和以后的隊伍的。對于敵方的一只軍隊,找到我方中,能消滅他的,且不被他消滅的最小生命值,倘若不存在,則犧牲multiset中最小的那個值。


總結(jié):

??? 對于貪心問題,要明確貪心策略,理清思路,才能有助于解題。


補充:

??? 另外multiset的使用也需小心,erase操作,對應(yīng)兩種參數(shù),如果是一個數(shù)值的話,那刪除的是所有該數(shù)值的值,如果是一個迭代器,那只刪除該迭代器對應(yīng)的值。詳見此博客。

代碼:


#include#include#include#include#includeusing?namespace?std;
struct?troop
{
	//傷害,生命值
	int?harm,life;
}us[100010],en[100010];
//按攻擊力排序
bool?cmp1(troop?a,troop?b)
{
	return?a.harm>b.harm;
}
//按生命值排序
bool?cmp2(troop?a,troop?b)
{
	return?a.life>b.life;
}
int?main()
{
	int?t,p=0,cnt,n,m;
	bool?flag;
	scanf("%d",&t);
	for(int?i=1;i<=t;i++)
	{
		printf("Case?#%d:?",i);
		scanf("%d%d",&n,&m);
????????for(int?j=0;j<n;j++)
			scanf("%d%d",&us[j].harm,&us[j].life);
		for(int?j=0;j<m;j++)
			scanf("%d%d",&en[j].harm,&en[j].life);
		//如果我方軍隊數(shù)量小于敵方,直接輸出-1
		if(n<m)
		{
			printf("-1n");
			continue;
		}
		//我方按攻擊力高排序
		sort(us,us+n,cmp1);
		//敵方按生命值排序
		sort(en,en+m,cmp2);
		//存儲我方的攻擊力
		multiset?defense;
		//p我方下標(biāo),cnt我方犧牲數(shù)量
		p=cnt=0;
		flag=true;
????????for(int?j=0;j<m;j++)
		{
			for(int?k=p;k=en[j].life)
				{
					defense.insert(us[k].life);
					p++;
				}
				else?break;
			}
			//如果我方剩余軍隊不能消滅敵方隊伍,break,輸出-1
			if(defense.empty())
			{
				flag=false;
				break;
			}
			else
			{
			???//能不損失軍隊,則用我方生命值恰好高于敵方的去消滅
			???//倘若必須損失軍隊,則損失當(dāng)前生命值最低的
			???multiset::iterator?it;
???????????????it=defense.upper_bound(en[j].harm);
			???if(it!=defense.end())
				???defense.erase(it);
			???else
			???{
				???defense.erase(defense.begin());
				???cnt++;
			???}
			}
		}
		if(!flag)
			printf("-1n");
		else?
			printf("%dn",n-cnt);
	}
	return?0;
}




本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉