9/10 資訊能競培訓

自我介紹

我們在這幹嘛

校內複賽 10/8 選校隊(11 + 4)
北市賽 11月? 前二等獎進全國
(我猜10個?)
全國賽 12月(19)日 前二等獎進資奧一階選訓
(10個)

選訓??

入營考 3月嗎 選20人進一階
(資格!年級保障!)
資奧一階 3月嗎 模考*2
選12人進二階(推薦、亞太)
資奧二階 4月嗎 模考*2
選4人當國手
國際資奧 6月 新加坡go go
金銀銅牌

除此之外

ISSC 10/17
報名剩九天
一校最多報兩隊
找其它校?
聽說有國際賽
HP codewars 11月? 參加、吃、抽、奇怪項目
NPSC 11月初賽
12月決賽
初賽取25隊,一校最多3隊!
吃、氣球
不知為何推?
YTP 暑假? 吃爆
最容易賺錢
適合同分

三人團體賽!!!

除此之外

享受想題、解題的樂趣!
為人類謀幸福

變強的方法

寫題目
寫題目
寫題目

TIOJ
codeforces

請補充QQ

所以,到底競程是啥?

欸不是,大家都比過初賽了ㄅ

如何解題

1.思考性質(optional)
2.設計算法
3.驗證複雜度
4.開寫
*小測資很重要

(時間)複雜度

一個描述演算法執行時間的函式

舉例來說

班上有\(n\)個人,我們想要知道哪兩個人一起玩兩人三腳最快,於是把所有兩人一組的可能都試過,並假設一次只能讓一組進行兩人三腳,且必須花費10秒(常數時間)

時間複雜度\(T(n) = \frac{n(n-1)}{2}\times 10 = 5n^2 - 5n\) 

Big-O

\(\exist M \in \R^+,x_0 \in \R,s.t. \forall x \geq x_0,|f(x)| \leq M|g(x)| \)

\(f(x) = O(g(x)) \)

簡單來說

保留最高(增長最快)項,常數bye bye

\(T(n) = 5n^2 + 5n = O(n^2)\)

莫非定律

函式中有多個變數?

神秘數字

一秒\(10^8\)(左右)

Ex. \(O(n^2)\) 最多可以跑到\(10^4\)左右

Q&A

為甚麼要去掉低次項跟常數?

簡潔

常數去掉不會有事嗎?

...卡常數的題不該出現在世界上

空間複雜度

1.一樣,只是用來描述所使用的空間大小

3.空間複雜度小於等於時間複雜度

STL(我會的部分)

演算法

#include<iostream>
#include<algorithm>
using namespace std;
int A[5] = {2,4,1,3,5};
int main()
{
    sort(A,A+5);//O(nlogn)
    cout << *lower_bound(A,A+5,4) << endl;//O(logn)
    cout << *upper_bound(A,A+5,4) << endl;//O(logn)
}
//reverse

pair

#include<iostream>
#include<utility>
#include<algorithm>
using namespace std;
int main()
{
    pair<int,int> A[3];
    A[0] = {1,4};
    A[1] = {5,2};
    A[2] = {0,10};
    sort(A,A+3);
    for(int i = 0;i < 3;i++)
    {
        cout << A[i].first << " " << A[i].second << endl;
    }
}

容器

Stack

Queue

#include<iostream>
#include<stack>
using namespace std;
stack<int> stk;
int main()
{
    stk.push(5);
    stk.push(3);
    cout << stk.size() <<endl;
    cout << stk.top() << endl;
    stk.pop();
    //通通O(1)
}
#include<iostream>
#include<stack>
using namespace std;
queue<int> que;
int main()
{
    que.push(5);
    que.push(3);
    cout << que.empty() <<endl;
    cout << que.front() << endl;
    que.pop();
    //通通O(1)
}

priority_queue
取出最大值的queue

#include<iostream>
#include<queue>
using namespace std;
int main()
{
    priority_queue<int,vector<int>,greater<int> > pq;
    //                 照打         小於函式
    pq.push(5);//O(logn)
    pq.push(3);
    pq.push(4);
    cout << pq.top() <<endl;//O(1)
    pq.pop();//O(logn)
    cout << pq.top() <<endl;
    pq.pop();
    cout << pq.top() <<endl;
    pq.pop();
}

vector
可變長度陣列?

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
vector<int> vec = {1,2,3};
int main()
{
    vec.clear();
    vec.push_back(0);
    vec.push_back(8);
    vec.push_back(5);
    vec.push_back(9);
    vec.pop_back();//以上都O(1)
    cout << vec[0] <<endl;
    sort(vec.begin(),vec.end());//想成指標
    for(auto x : vec)
    {
    	cout << x << " ";
    }
}

deque
double-ended queue

#include<iostream>
#include<deque>
using namespace std;
int main()
{
    deque<int> deq;
    deq.push_back(1);
    deq.push_back(4);
    deq.push_front(5);
    deq.push_front(3);
    cout << deq[2] << endl;
    deq.pop_back();//以上都O(1)
    for(auto x : deq)
    {
        cout << x << " ";
    }
}

set
有序集合?

#include<iostream>
#include<set>
using namespace std;
int main()
{
    set<int> st;
    st.insert(5);
    st.insert(3);
    st.insert(8);
    st.insert(5);
    st.erase(3);//以上都O(logn)
    for(auto x : st)
        cout << x << " ";
    cout << endl;
    cout << (*st.begin()) <<endl;//O(1)
    cout << (*prev(st.end())) << endl;//O(1)
    cout << st.count(5) <<endl;//O(logn)
    cout << *st.lower_bound(3) << endl;//O(logn)
}

multiset

#include<iostream>
#include<set>
using namespace std;
int main()
{
    multiset<int> st;
    st.insert(5);
    st.insert(3);
    st.insert(8);
    st.insert(5);
    st.erase(3);//以上都O(logn)
    for(auto x : st)
        cout << x << " ";
    st.erase(st.find(5));//O(logn)
}

unordered_set

#include<iostream>
#include<unordered_set>
using namespace std;
int main()
{
    unordered_set<int> st;
    s.reserve(32768); //聽說會變快
    s.max_load_factor(0.25); //聽說會變快
    st.insert(5);
    st.insert(3);
    st.insert(8);
    st.insert(5);
    st.erase(3);//以上都O(1)
    for(auto x : st)
        cout << x << " ";
}

unordered_multiset

map
有序映射

#include<iostream>
#include<map>
#include<algorithm>
using namespace std;
int main()
{
    map<int,int> mp;
    mp[4] = 3;
    mp[5] = 9;
    mp.insert({3,9});//以上都O(logn)
    for(auto x : mp)
    {
        cout << x.first << " " << x.second << endl;
    }
    cout << mp.count(8) <<endl;//O(logn)
    cout << mp[8] <<endl;//O(logn)
    cout << mp.count(8) <<endl;
}

multimap(沒用過)
unordered_map
unorderd_multimap

習題

ZJ b298

ZJ c123
ZJ b231
​TIOJ 1807

bitset

#include<bits/stdc++.h>
using namespace std;
int main()
{
    bitset<10>a(6);
    bitset<10>b("111");
    cout << a << endl;
    cout << b <<endl;
    b.reset();//O(N)
    b[2] = 1;
    cout << a.to_ulong() + b.to_ulong() <<endl;//O(N)
    cout << (a ^ b) << endl;//32 times faster?
}

deck

By Zi-Hong Xiao

deck

  • 1,679