BZOJ 1568: [JSOI2008]Blue Mary開公司(超哥線段樹)

来源:http://www.cnblogs.com/zwfymqz/archive/2017/08/08/7305682.html
-Advertisement-
Play Games

1568: [JSOI2008]Blue Mary開公司 Description Input 第一行 :一個整數N ,表示方案和詢問的總數。 接下來N行,每行開頭一個單詞“Query”或“Project”。 若單詞為Query,則後接一個整數T,表示Blue Mary詢問第T天的最大收益。 若單詞為 ...


1568: [JSOI2008]Blue Mary開公司

Time Limit: 15 Sec  Memory Limit: 162 MB
Submit: 1080  Solved: 379
[Submit][Status][Discuss]

Description

Input

第一行 :一個整數N ,表示方案和詢問的總數。  接下來N行,每行開頭一個單詞“Query”或“Project”。  若單詞為Query,則後接一個整數T,表示Blue Mary詢問第T天的最大收益。  若單詞為Project,則後接兩個實數S,P,表示該種設計方案第一天的收益S,以及以後每天比上一天多出的收益P。 1 <= N <= 100000 1 <= T <=50000 0 < P < 100,| S | <= 10^6  提示:本題讀寫數據量可能相當巨大,請選手註意選擇高效的文件讀寫方式。

Output

對於每一個Query,輸出一個整數,表示詢問的答案,並精確到整百元(以百元為單位,

 

例如:該天最大收益為210或290時,均應該輸出2)。沒有方案時回答詢問要輸出0

Sample Input

10
Project 5.10200 0.65000
Project 2.76200 1.43000
Query 4
Query 2
Project 3.80200 1.17000
Query 2
Query 3
Query 1
Project 4.58200 0.91000
Project 5.36200 0.39000

Sample Output

0
0
0
0
0

HINT

 

Source

 

超哥線段樹的模板題。

超哥線段樹是處理一次函數的一種線段樹,

在超哥線段樹中,每一個節點保存著一個一次函數所對應的編號,

那他是怎麼保存的呢?

借用一位大神的圖片

沒錯就是這樣,

然後對於每一次插入操作,

我們去遞歸當前 值小的節點 的值 可能比 值大的節點 的 值 大的方向。。。。。。。

 

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<bitset>
#define ls k<<1
#define rs k<<1|1
using namespace std;
const int MAXN=1000001;
inline void read(int &n)
{
	char c='+';int x=0;bool flag=0;
	while(c<'0'||c>'9'){c=getchar();if(c=='-')flag=1;}
	while(c>='0'&&c<='9'){x=x*10+(c-48);c=getchar();}
	n=flag==1?-x:x;
}
struct funtion
{
	double k,b;
}a[MAXN];// 記錄每一條線段 
int tree[MAXN];// 每一個節點所對應線段的編號 
int tot=0;// 總的線段數量 
inline int pd(int now,int will,int day)
{
	--day;
	return a[now].k*day+a[now].b>a[will].k*day+a[will].b;
}
inline void insert(int k,int l,int r,int now)
{
	if(l==r)
	{
		if(pd(now,tree[k],l))	tree[k]=now;
		return ;
	}
	int mid=(l+r)>>1;
	if(a[now].k>a[tree[k]].k)// 當前點的斜率比目標點的斜率大 
	{
		if(pd(now,tree[k],mid))	insert(ls,l,mid,tree[k]),tree[k]=now;
		else	insert(rs,mid+1,r,now);
	}
	else
	{
		if(pd(now,tree[k],mid))	insert(rs,mid+1,r,tree[k]),tree[k]=now;
		else	insert(ls,l,mid,now);
	}
}
double ans=0;
void query(int k,int l,int r,int now)
{
	ans=max(ans,a[tree[k]].k*(now-1)+a[tree[k]].b);
	if(l==r)	return ;
	int mid=(l+r)>>1;
	if(now<=mid)	query(ls,l,mid,now);
	else 	query(rs,mid+1,r,now);
}
int main()
{
	ios::sync_with_stdio(0);
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		string opt;
		cin>>opt;
		if(opt[0]=='P')
		{
			++tot;
			cin>>a[tot].b>>a[tot].k;
			insert(1,1,n,tot);
		}
		else if(opt[0]=='Q')
		{
			int p;
			cin>>p;
			ans=0;
			query(1,1,n,p);
			printf("%d\n",(int)(ans/100));
		}
	}
	return 0;
}

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Tag Helpers 提供了在視圖中更改和增強現有HTML元素的功能。將它們添加到視圖中,會經過Razor模板引擎處理並創建一個HTML,之後再返回給瀏覽器。 ...
  • 最近在看《編程珠璣》,挺有意思,驚嘆於作者思維的巧妙。閑來無事,就想著開了博客練練手。內容都是從書上的,我就用C#簡單實現了一下。鄙人只是剛出道的小小程式猿,第一次寫博客,實在寫不出太優秀的代碼,望看到的人多多見諒哈。。有錯誤或者意見啥的隨便提,也是我學習的機會。 書上的內容大致是:給定一個英語詞典 ...
  • 1 那就從簡單的標簽說起吧!1.x中常用的標簽只有4中html、bean、logic、tiles 2 3 而struts2.0里的標簽卻沒有分類,只用在jsp頭文件加上 4 5 6 就能使用struts2.0的標簽庫 7 8 9 下麵就介紹每個標簽的具體應用實例說明:按字母排列 10 11 12 A... ...
  • (1) dictionary 用 method item()可以同時得到key和value (2) 用emurate輪詢List可以同時得到索引和值(3) 假如需要同時輪詢兩個或多個序列,可以使用zip() (4) 如果需要反向輪詢,可以用reversed ...
  • 首先瞭解線程的狀態轉換圖: 在Java中一個類要當做線程來使用有兩種方法: 1)繼承Thread類,並重寫run函數 2)實現Runable介面,並重寫run函數 Java是單繼承的,但某些情況下一個類可能已經繼承了某個父類,則不能再繼承Thread類創建線程,只能用第二種。 下麵是針對同一問題“編 ...
  • 該文檔為轉載內容: 加密解密 1 前端js加密概述 2 前後端加密解密 21 引用的js加密庫 22 js加密解密 23 Java端加密解密PKCS5Padding與js的Pkcs7一致 驗證碼 1 概述 2 驗證碼生成器 3 控制器使用驗證碼 如 CodeController 應用 1 login ...
  • t = (1, 2, ‘hl’)x, y, z = t上述方法可用於任何sequence ...
  • package com.hd.action; import java.util.Map; import javax.servlet.ServletContext; import javax.servlet.http.HttpServlet; import javax.servlet.http.Htt... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...