簡單的卡常數【OI縮水版】
一、為什麼要卡常數?
- OI中資料結構與常數優化關係很大的
- 如果你常數好可以暴力過資料結構題啦~
- 如果你常數不好即使複雜度一樣也會被出題人卡~
二、常用的卡常數方法
1、卡IO(輸入輸出)
比較簡單的寫法:
int readint(){
int op=1,x=0; char ch=getchar();
while(ch<'0' || ch>'9'){if(ch=='-')op=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return op*x;
}
void outint(int x){
if(x<0){putchar('-');x=-x;}
if(x>9)outint(x/10);
putchar(x%10+'0');
}
比較奇怪的寫法
mmap
2、卡編譯
2.1 C++行內函數inline
:
由編譯器在編譯時會在主程式中把函式的內容直接展開替換,減少了記憶體訪問。(如果是遞迴可能會展開前幾層的運算吧?)
int max(int a, int b){return a>b?a:b;}//原函式
inline int max(int a, int b){return a>b?a:b;}//前面直接加inline就好了。
2.2 CPU暫存器變數register
:
對於一些頻繁使用的變數,可以宣告時加上該關鍵字,執行時可能會把該變數放到CPU暫存器中,只是可能,不保證有效。特別是你變數多的時候,一般還是丟到記憶體裡面的。
比較下面兩段程式:
register int a=0;
for(register int i=1;i<=999999999;i++)a++;
int a=0;
for(int i=1;i<=999999999;i++)a++;
優化:0.2826 second
不優化:1.944 second
3、卡計算
3.1 取模優化
佔坑待填,據說 https://loj.ac/article/327
3.2 加法優化
用++i
代替i++
。
1. 後置++需要儲存臨時變數以返回之前的值,在 STL 中非常慢。
2. 事實上,int的後置++ 在實測中也比前置++ 慢0.5倍左右(UOJ 上自定義測試)
3.3 陣列優化
1、不要開bool,所有bool改成char,int是最快的(原因不明)。
2、在最大值50000*50000的時候用unsigned代替long long
3、對於多維陣列,用到乘法優化定址
// Code A
for(i=1;i<=n;i++)
ans+=A[x][y][z][i];
// Code B
int *p=A[x][y][z];
for(i=1;i<=n;i++)
ans+=*(p+i);
3.4 判斷優化
if()else語句比()?():()語句要慢,逗號運算子比分號運算子要快。
3.5 結構優化
1.如果你要經常呼叫a[x],b[x],c[x]這樣的陣列,把她們寫在同一個結構體裡面會變快一些,比如f[x].a, f[x].b, f[x].c
2.指標比下標快。
3.7 歡迎補充
4、卡演算法/預處理
4.1 STL優化
STL非常慢,可以手寫。
4.2 倍增優化
倍增表小的開前面——定址會變快很多
4.3 Floyd初始化
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
gra[i][j]=inf
for(int i=1;i<=b;i++)
gra[i][i]=0
是比
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
if(i==j) gra[i][j]=0;
else gra[i][j]=inf
}
快80%以上的,,因為要每次去比較。
4.4 迴圈展開
自己感受。。。
void Init_Array(int *dest, int n)
{
int i;
for(i = 0; i < n; i++)
dest[i] = 0;
}
void Init_Array(int *dest, int n)
{
int i;
int limit = n - 3;
for(i = 0; i < limit; i+= 4)//每次迭代處理4個元素
{
dest[i] = 0;
dest[i + 1] = 0;
dest[i + 2] = 0;
dest[i + 3] = 0;
}
for(; i < n; i++)//將剩餘未處理的元素再依次初始化
dest[i] = 0;
}
4.5 佔坑待填。
相關文章
- 程式碼除錯技巧【OI縮水版】除錯
- OI常見思維方式1(簡單/特殊情形——數學相關)
- OI/ACM最全卡常大招ACM
- 簡單解壓縮工具:OmniZip - Universal Extractor Pro 中文啟用版
- 數學 in OI-數論-1
- 簡單好用的js 壓縮工具JS
- 簡單實用的mac壓縮解壓軟體:iFastZip for Mac中文版MacAST
- 常見的 Go 變數縮寫對照表Go變數
- 精簡版 koa 簡單實現
- 簡單瞭解一下壓縮表
- 【leetcode 簡單】 第一百零六題 壓縮字串LeetCode字串
- JavaScript圖片簡單等比例縮放JavaScript
- 批次壓縮影片大小的簡單操作分享
- 簡單版Promise實現Promise
- this的指向(簡單描述版)
- 簡單版—返回頂部
- 簡單題 加強版
- Word檔案太大怎麼壓縮,分享壓縮Word的簡單方法
- 怎麼把影片壓縮?實用又簡單的壓縮影片方法
- 【Node】簡單快捷的圖片壓縮指令碼指令碼
- Hive的壓縮儲存和簡單優化Hive優化
- 「Photoshop2021入門教程」等比例縮小的卡通人物
- [OI] Testlib
- OI Wiki
- 中國特供版RTX 4090D效能對比 全面縮水超頻也砍了
- 簡單版AC自動機
- 【模板】樹分塊(簡單版)
- 簡單解析MySQL中的cardinality異常MySql
- 手機將PDF檔案壓縮的簡單方法
- 簡單聊聊 GZIP 的壓縮原理與日常應用
- 簡單實用的mac壓縮軟體:iZip for MacMac
- Hadoop上配置snappy壓縮格式(最簡單的做法)HadoopAPP
- 三種簡單的PDF檔案快速壓縮方法
- 百度簡單搜尋PC版玩法攻略 簡單搜尋有電腦版嗎?
- 瘋狂拆拆樂:玩法簡單易於上手的卡牌小遊戲如何做到策略多樣?遊戲
- 百萬點贊怎麼來?Python批量製作抖音的卡點視訊原來這麼簡單!Python
- OI日記
- 結束OI