From c85edc8a2e07a27b82e75bf611d471f8e82e4eca Mon Sep 17 00:00:00 2001 From: Xi Ruoyao Date: Thu, 5 May 2022 17:38:40 +0800 Subject: [PATCH] first commit --- .gitignore | 10 ++ .gitmodules | 3 + Makefile | 38 ++++++ XDUtheme | 1 + beamer.tex | 246 +++++++++++++++++++++++++++++++++++ beamercolorthemeXDUstyle.sty | 1 + beamerinnerthemeXDUstyle.sty | 1 + beamerouterthemeXDUstyle.sty | 1 + beamerthemeXDUstyle.sty | 1 + code/.gitignore | 8 ++ code/Makefile | 15 +++ code/abs.cc | 9 ++ code/abs.sh | 2 + code/bsrch.cc | 11 ++ code/bsrch.sh | 2 + code/gen.py | 32 +++++ code/map.cc | 12 ++ code/map.sh | 2 + code/multiset.cc | 9 ++ code/multiset.sh | 2 + code/namespace.cc | 15 +++ code/set.cc | 9 ++ code/set.sh | 2 + code/set2.cc | 11 ++ code/set2.sh | 2 + code/set3.cc | 13 ++ code/set3.sh | 2 + code/sort-vec.cc | 20 +++ code/sort-vec.sh | 2 + code/sort.cc | 12 ++ code/sort.sh | 2 + code/using-std.cc | 10 ++ code/xchg1.c | 12 ++ code/xchg2.cc | 12 ++ code/xchg3.cc | 13 ++ code/xchg4.cc | 15 +++ theme | 1 + 37 files changed, 559 insertions(+) create mode 100644 .gitignore create mode 100644 .gitmodules create mode 100644 Makefile create mode 120000 XDUtheme create mode 100644 beamer.tex create mode 120000 beamercolorthemeXDUstyle.sty create mode 120000 beamerinnerthemeXDUstyle.sty create mode 120000 beamerouterthemeXDUstyle.sty create mode 120000 beamerthemeXDUstyle.sty create mode 100644 code/.gitignore create mode 100644 code/Makefile create mode 100644 code/abs.cc create mode 100644 code/abs.sh create mode 100644 code/bsrch.cc create mode 100644 code/bsrch.sh create mode 100755 code/gen.py create mode 100644 code/map.cc create mode 100644 code/map.sh create mode 100644 code/multiset.cc create mode 100644 code/multiset.sh create mode 100644 code/namespace.cc create mode 100644 code/set.cc create mode 100644 code/set.sh create mode 100644 code/set2.cc create mode 100644 code/set2.sh create mode 100644 code/set3.cc create mode 100644 code/set3.sh create mode 100644 code/sort-vec.cc create mode 100644 code/sort-vec.sh create mode 100644 code/sort.cc create mode 100644 code/sort.sh create mode 100644 code/using-std.cc create mode 100644 code/xchg1.c create mode 100644 code/xchg2.cc create mode 100644 code/xchg3.cc create mode 100644 code/xchg4.cc create mode 160000 theme diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..b43fb20 --- /dev/null +++ b/.gitignore @@ -0,0 +1,10 @@ +*.aux +*.fdb_latexmk +*.fls +*.log +*.nav +*.out +*.pdf +*.snm +*.toc +*.vrb diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 0000000..e164e95 --- /dev/null +++ b/.gitmodules @@ -0,0 +1,3 @@ +[submodule "theme"] + path = theme + url = https://github.com/xdu-icpc/XDUstyle-Beamer-Theme diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..39ed52e --- /dev/null +++ b/Makefile @@ -0,0 +1,38 @@ +STYFILES = beamerthemeXDUstyle.sty \ + beamercolorthemeXDUstyle.sty \ + beamerinnerthemeXDUstyle.sty \ + beamerouterthemeXDUstyle.sty \ + +OUTFILES = abs.out sort.out bsrch.out sort-vec.out set.out set2.out \ + set3.out multiset.out map.out + +GENERATED = *.aux *.fdb_latexmk *.fls *.log *.nav *.out *.pdf *.snm *.toc \ + *.vrb + +all: beamer + +.PHONY: beamer +beamer: $(STYFILES) + make -C code $(OUTFILES) + latexmk --lualatex beamer + +.PHONY: exercise +exercise: + make -C exercise + +.PHONY: recitation +recitation: $(STYFILES) + latexmk --lualatex recitation + +.PHONY: clean +clean: + rm -fv $(GENERATED) + make -C exercise clean + make -C code clean + +.PHONY: .gitignore +.gitignore: + echo "$(GENERATED)" | sed 's/ /\n/g' > $@ + +$(STYFILES): theme/XDUstyle.dtx + cd theme; xelatex XDUstyle.dtx diff --git a/XDUtheme b/XDUtheme new file mode 120000 index 0000000..a5ed6ca --- /dev/null +++ b/XDUtheme @@ -0,0 +1 @@ +theme/XDUtheme \ No newline at end of file diff --git a/beamer.tex b/beamer.tex new file mode 100644 index 0000000..2db19dd --- /dev/null +++ b/beamer.tex @@ -0,0 +1,246 @@ +%!TEX program = lualatex +\documentclass[10pt,mathserif]{beamer} + +\usepackage{luatexja} +\usepackage{luatexja-fontspec} +\setmainjfont[ + RawFeature={instance=Regular}, + BoldFont=Noto Sans CJK SC, + BoldFeatures={RawFeature={instance=Bold}}, + Renderer=Harfbuzz, +]{Noto Sans CJK SC} + +\setmonofont[ + RawFeature={instance=Regular}, + BoldFont=Noto Sans Mono, + BoldFeatures={RawFeature={instance=Bold}}, + ItalicFont=Noto Sans Mono, + ItalicFeatures={RawFeature={instance=Italic}}, + Renderer=Harfbuzz, +]{Noto Sans Mono} + +\newfontfamily\light{Noto Sans Mono}[ + RawFeature={instance=ExtraLight}, + Renderer=Harfbuzz, +] + +\definecolor{xdublue}{RGB}{0,65,130} + +\usepackage{listings} +\lstset{ +basicstyle=\small\ttfamily, +keywordstyle=\color{xdublue}, +numbers=left, +numberstyle=\tiny\light, +commentstyle=\light, +frame=leftline, +tabsize=4 +} + +\lstdefinestyle{term} +{basicstyle=\ttfamily, numbers=none, frame=single, breaklines=true, +moredelim={[is][keywordstyle]{@@}{@@}}} + +\newcommand{\lstcode}[1] { \lstinputlisting[language=C++]{code/#1} } +\newcommand{\lstterm}[1] { \lstinputlisting[style=term]{code/#1} } + +\usepackage{ulem} + +\usetheme[xdblue]{XDUstyle} + +\title{C++ Subset for Comptitive Programming} +\institute{西安电子科技大学程序设计竞赛实训基地} +\author{席若尧} +\date{2022 年 5 月 3 日} + +\begin{document}% +{\xdbg \frame[plain,noframenumbering]{\titlepage}} + +\begin{frame}{内容} + \tableofcontents[hideallsubsections] +\end{frame} + +\section{为什么用 C++} +\sectionpage + +\begin{frame}{为什么不用 C} + \begin{itemize} + \item Q: 我只会 C,能打 ACM 吗? + \pause + \item 大佬: 能,用 C 连 Linux 内核都能写出来,还写不出几个算法题? + \pause + \item 我: 但是你能手写红黑树的 5 种插入和 7 种删除吗…… + Linux 内核的红黑树代码 334 行。 + \end{itemize} +\end{frame} + +\begin{frame}{为什么不用 Java} + \begin{itemize} + \item Q: 人家大公司都用 Java,我用这个东西打比赛也没问题罢? + \pause + \item 大佬: 没问题,我只会 Java 都打到 CF LGM 了。 + \pause + \item 但是 Java 这个东西在用得好的人和一般人手里效率差距很大, + 比如要用 Java 打比赛首先需要写个高效率 I/O 库,如果你直接用 + Java 自带的 I/O 连 A+B 都能超时。 + \item 随着 JVM 的进步,目前多数评测环境已经不再为 Java 单独开时限。 + \pause + \item Kotlin 基本就是 Java 套壳,同理。 + \end{itemize} +\end{frame} + +\begin{frame}{为什么不用 Python} + \begin{itemize} + \item Q: 学术界 Python 都能算神经网络, + 我用这个东西打比赛也没问题罢? + \item 人学术界是用 Python 封装 C/C++ 写的运算库, + 比赛时候没有运算库给你用,而且目前评测系统不支持你自己写运算库。 + \item 只用纯 Python 的话就算你再强,写大多数题目都会超时。 + 当然有的特殊题目 (高精度,简单的字符串处理等) 是可以用的…… + \end{itemize} +\end{frame} + +\begin{frame}{为什么不用 XXX} + \begin{itemize} + \item Pascal, Go, Rust, OCamal (@zzs), MATLAB, Brainf**k, …… + \item 因为 (正式) 比赛用不了 + \item 总而言之,是因为 C++ 的语言特性和标准库提供的功能比较适合 + 这个比赛 + \end{itemize} +\end{frame} + +\section{一些 C 语言老师应该讲但是没讲/讲错的东西} +\sectionpage + +\begin{frame}{误区} + \begin{itemize} + \item Q: C 是 C++ 的子集? + \pause + \item A: 并不是 + \begin{itemize} + \item C++ 具有更严格的类型检查要求 + \item \lstinline{inline} 等一些东西虽然看起来是一样的, + 但是语义上有微妙的差别 + \end{itemize} + \end{itemize} +\end{frame} + +\begin{frame}{误区} + \begin{itemize} + \item 如果你不确定你的程序会如何表现,就跑一下试试 + \pause + \item 这相当于说:如果你不确定一个化学反应是什么样的, + 就直接在试管里试一试 + \pause + \item 使用未初始化值、数组越界、带符号整数溢出等都具有不确定的行为, + 这些在不同的机器上,使用不同的编译器或编译选项时, + 甚至重复运行时都可能产生出乎意料的不同结果 + \end{itemize} +\end{frame} + +\section{竞赛中可能用到的 C++ 特性} + +\begin{frame}{一个 C 程序} + 我们从一个 C 语言中“交换两个整数”的子程序开始: + \lstcode{xchg1.c} + \pause + \begin{itemize} + \item \lstinline{*} 和 \lstinline{&} 之类的东西很多…… + \end{itemize} +\end{frame} + +\begin{frame}{引用类型} + C++ 引入了引用类型,它基本就是指针套壳: + \lstcode{xchg2.cc} + \pause + \begin{itemize} + \item 只能交换 \lstinline{int} + \end{itemize} +\end{frame} + +\begin{frame}{函数重载} + 重载允许我们编写同名,但参数类型不同的子程序: + \lstcode{xchg3.cc} +\end{frame} + +\begin{frame}{例:绝对值函数} + \lstcode{abs.cc} + 输出为: + \lstterm{abs.out} +\end{frame} + +\begin{frame}{函数模板} + 模板使得编译器为多种类型自动生成重载函数: + \lstcode{xchg4.cc} +\end{frame} + +\begin{frame}{命名空间} + 命名空间可以用于防止名称冲突: + \lstcode{namespace.cc} +\end{frame} + +\begin{frame}{std 命名空间} + C++ 标准库中的所有名称都位于 \lstinline{std} 命名空间中, + 所以很多竞赛程序都会直接导入其中的所有名称以便使用: + \lstcode{using-std.cc} + 但是这在写软件项目时通常是不允许的,也有一些竞赛选手不喜欢这样做。 +\end{frame} + +\begin{frame}{标准库的排序函数} + \lstcode{sort.cc} + 输出为: + \lstterm{sort.out} + 如无特殊需要,比赛时不要写任何排序算法! +\end{frame} + +\begin{frame}{二分查找函数} + \lstcode{bsrch.cc} + 输出为: + \lstterm{bsrch.out} + 区间 $[l, r)$ 包含了所有的 $4$。 +\end{frame} + +\begin{frame}{重载运算符} + \lstcode{sort-vec.cc} +\end{frame} + +\begin{frame}{重载运算符} + 输出为: + \lstterm{sort-vec.out} +\end{frame} + +\begin{frame}{set} + \lstinline{std::set} 是一种基于有序数据结构的 (具体来说是二叉搜索树) + 集合类型。 + \lstcode{set.cc} + \lstterm{set.out} +\end{frame} + +\begin{frame}{动态插入和删除} + \lstcode{set2.cc} + \lstterm{set2.out} +\end{frame} + +\begin{frame}{二分查找} + \lstcode{set3.cc} + \lstterm{set3.out} +\end{frame} + +\begin{frame}{multiset} + 和 \lstinline{set} 类似,但是允许重复元素: + \lstcode{multiset.cc} + \lstterm{multiset.out} +\end{frame} + +\begin{frame}{map} + 除了集合以外,还维护该集合上的一个映射: + \lstcode{map.cc} + \lstterm{map.out} +\end{frame} + +{\xdbg%末页致谢 +\begin{frame}[plain,noframenumbering] + \finalpage{{\huge GL and HF!}} +\end{frame}} + +\end{document} diff --git a/beamercolorthemeXDUstyle.sty b/beamercolorthemeXDUstyle.sty new file mode 120000 index 0000000..b2f7d2d --- /dev/null +++ b/beamercolorthemeXDUstyle.sty @@ -0,0 +1 @@ +theme/beamercolorthemeXDUstyle.sty \ No newline at end of file diff --git a/beamerinnerthemeXDUstyle.sty b/beamerinnerthemeXDUstyle.sty new file mode 120000 index 0000000..246a9d6 --- /dev/null +++ b/beamerinnerthemeXDUstyle.sty @@ -0,0 +1 @@ +theme/beamerinnerthemeXDUstyle.sty \ No newline at end of file diff --git a/beamerouterthemeXDUstyle.sty b/beamerouterthemeXDUstyle.sty new file mode 120000 index 0000000..92ad154 --- /dev/null +++ b/beamerouterthemeXDUstyle.sty @@ -0,0 +1 @@ +theme/beamerouterthemeXDUstyle.sty \ No newline at end of file diff --git a/beamerthemeXDUstyle.sty b/beamerthemeXDUstyle.sty new file mode 120000 index 0000000..a6543ee --- /dev/null +++ b/beamerthemeXDUstyle.sty @@ -0,0 +1 @@ +theme/beamerthemeXDUstyle.sty \ No newline at end of file diff --git a/code/.gitignore b/code/.gitignore new file mode 100644 index 0000000..4601570 --- /dev/null +++ b/code/.gitignore @@ -0,0 +1,8 @@ +*.gcda +*.gcno +*.gcov +*.out +*.s +*.exe +*.in +*.o diff --git a/code/Makefile b/code/Makefile new file mode 100644 index 0000000..0701ec4 --- /dev/null +++ b/code/Makefile @@ -0,0 +1,15 @@ +all: + @echo "usage: $(MAKE) something.out" + +%.out: %.sh %.cc gen.py + ./gen.py $< $@ + +GENERATED = *.gcda *.gcno *.gcov *.out *.s *.exe *.in *.o + +.PHONY: .gitignore +.gitignore: + echo "$(GENERATED)" | sed 's/ /\n/g' > $@ + +.PHONY: clean +clean: + rm -fv $(GENERATED) diff --git a/code/abs.cc b/code/abs.cc new file mode 100644 index 0000000..53bba43 --- /dev/null +++ b/code/abs.cc @@ -0,0 +1,9 @@ +#include +#include + +int main() +{ + double wrong = abs(114.514); + double correct = std::abs(114.514); + printf("%.10f %.10f\n", wrong, correct); +} diff --git a/code/abs.sh b/code/abs.sh new file mode 100644 index 0000000..4d280e7 --- /dev/null +++ b/code/abs.sh @@ -0,0 +1,2 @@ +g++ abs.cc -o abs.exe +./abs.exe diff --git a/code/bsrch.cc b/code/bsrch.cc new file mode 100644 index 0000000..da31779 --- /dev/null +++ b/code/bsrch.cc @@ -0,0 +1,11 @@ +#include +using namespace std; + +int main() +{ + int a[] = {1, 1, 4, 5, 1, 4}; + sort(a, a + 6); + int l = lower_bound(a, a + 6, 4) - a; + int r = upper_bound(a, a + 6, 4) - a; + printf("%d %d\n", l, r); +} diff --git a/code/bsrch.sh b/code/bsrch.sh new file mode 100644 index 0000000..e16bed4 --- /dev/null +++ b/code/bsrch.sh @@ -0,0 +1,2 @@ +g++ bsrch.cc -o bsrch.exe +./bsrch.exe diff --git a/code/gen.py b/code/gen.py new file mode 100755 index 0000000..6649e5b --- /dev/null +++ b/code/gen.py @@ -0,0 +1,32 @@ +#!/usr/bin/env python3 + +import os, sys, subprocess + +inf = sys.argv[1] +ouf = sys.argv[2] +with open(ouf, "w") as o: + with open(inf) as f: + env = os.environ + env["PS1"] = "$\n" + env["LC_ALL"] = "C" + sh = subprocess.Popen(["sh", "-i"], stdin=subprocess.PIPE, + stdout=subprocess.PIPE, stderr=subprocess.STDOUT, + env=env) + while True: + sh.stdout.flush() + dat = sh.stdout.readline() + if dat == b"$\n": + # input cmd + l = f.readline(); + if l == "": + sh.stdin.write(b"exit\n") + sh.stdin.flush() + break; + o.write("shell$ @@" + l[:-1] + "@@\n") + sh.stdin.write(l.encode()) + sh.stdin.flush() + # skip the cmd line + sh.stdout.flush() + sh.stdout.readline() + else: + o.write(dat.decode()) diff --git a/code/map.cc b/code/map.cc new file mode 100644 index 0000000..694493d --- /dev/null +++ b/code/map.cc @@ -0,0 +1,12 @@ +#include +using namespace std; + +int main() +{ + map mp = { + {"Monday", 1}, {"Tuesday", 2}, {"Wednesday", 3}, + }; + cout << mp["Tuesday"] << '\n'; + cout << mp.lower_bound("Tue")->first << '\n'; + cout << mp.lower_bound("Tue")->second << '\n'; +} diff --git a/code/map.sh b/code/map.sh new file mode 100644 index 0000000..739aef9 --- /dev/null +++ b/code/map.sh @@ -0,0 +1,2 @@ +g++ map.cc -o map.exe +./map.exe diff --git a/code/multiset.cc b/code/multiset.cc new file mode 100644 index 0000000..2dc65e5 --- /dev/null +++ b/code/multiset.cc @@ -0,0 +1,9 @@ +#include +using namespace std; + +int main() +{ + multiset s = {1, 1, 4, 5, 1, 4}; + for (int a: s) + cout << a << '\n'; +} diff --git a/code/multiset.sh b/code/multiset.sh new file mode 100644 index 0000000..0954686 --- /dev/null +++ b/code/multiset.sh @@ -0,0 +1,2 @@ +g++ multiset.cc -o multiset.exe +./multiset.exe diff --git a/code/namespace.cc b/code/namespace.cc new file mode 100644 index 0000000..2629862 --- /dev/null +++ b/code/namespace.cc @@ -0,0 +1,15 @@ +namespace flukehn +{ + const int m = 998244353; + // 514 lines of code ... + poly poly_mul(poly a, poly b); +} + +int m; + +int main() +{ + using flukehn::poly; + poly a = geta(), b = getb(); + poly c = flukehn::poly_mul(a, b); +} diff --git a/code/set.cc b/code/set.cc new file mode 100644 index 0000000..2d9a17e --- /dev/null +++ b/code/set.cc @@ -0,0 +1,9 @@ +#include +using namespace std; + +int main() +{ + set s = {1, 1, 4, 5, 1, 4}; + for (int a: s) + cout << a << '\n'; +} diff --git a/code/set.sh b/code/set.sh new file mode 100644 index 0000000..f4f4a2e --- /dev/null +++ b/code/set.sh @@ -0,0 +1,2 @@ +g++ set.cc -o set.exe +./set.exe diff --git a/code/set2.cc b/code/set2.cc new file mode 100644 index 0000000..6d18060 --- /dev/null +++ b/code/set2.cc @@ -0,0 +1,11 @@ +#include +using namespace std; + +int main() +{ + set s = {1, 1, 4, 5, 1, 4}; + s.insert(2); + s.erase(4); + for (int a: s) + cout << a << '\n'; +} diff --git a/code/set2.sh b/code/set2.sh new file mode 100644 index 0000000..ec79f32 --- /dev/null +++ b/code/set2.sh @@ -0,0 +1,2 @@ +g++ set2.cc -o set2.exe +./set2.exe diff --git a/code/set3.cc b/code/set3.cc new file mode 100644 index 0000000..2d12b56 --- /dev/null +++ b/code/set3.cc @@ -0,0 +1,13 @@ +#include +using namespace std; + +int main() +{ + set s = {1, 1, 4, 5, 1, 4}; + cout << s.count(5) << '\n'; + cout << s.count(6) << '\n'; + auto it = s.lower_bound(4); // or 3 + cout << *it << '\n'; + it++; + cout << *it << '\n'; +} diff --git a/code/set3.sh b/code/set3.sh new file mode 100644 index 0000000..9d16e11 --- /dev/null +++ b/code/set3.sh @@ -0,0 +1,2 @@ +g++ set3.cc -o set3.exe +./set3.exe diff --git a/code/sort-vec.cc b/code/sort-vec.cc new file mode 100644 index 0000000..76e72ab --- /dev/null +++ b/code/sort-vec.cc @@ -0,0 +1,20 @@ +#include +using namespace std; + +struct vec +{ + int x, y; + long long len() const + { return 1ll * x * x + 1ll * y * y; } + bool operator < (const vec &rhs) const + { return len() < rhs.len(); } +}; + +int main() +{ + vec v[] = {{1, 1}, {4, 5}, {1, 4}}; + sort(v, v + 3); + for (int i = 0; i < 3; i++) + cout << v[i].x << ' ' << v[i].y << '\n'; + return 0; +} diff --git a/code/sort-vec.sh b/code/sort-vec.sh new file mode 100644 index 0000000..a1e9db7 --- /dev/null +++ b/code/sort-vec.sh @@ -0,0 +1,2 @@ +g++ sort-vec.cc -o sort-vec.exe +./sort-vec.exe diff --git a/code/sort.cc b/code/sort.cc new file mode 100644 index 0000000..62f0683 --- /dev/null +++ b/code/sort.cc @@ -0,0 +1,12 @@ +#include +using namespace std; + +int main() +{ + int a[] = {1, 1, 4, 5, 1, 4}; + sort(&a[0], &a[6]); + printf("%d", a[0]); + for (int i = 1; i < 6; i++) + printf(" %d", a[i]); + putchar('\n'); +} diff --git a/code/sort.sh b/code/sort.sh new file mode 100644 index 0000000..e41b57b --- /dev/null +++ b/code/sort.sh @@ -0,0 +1,2 @@ +g++ sort.cc -o sort.exe +./sort.exe diff --git a/code/using-std.cc b/code/using-std.cc new file mode 100644 index 0000000..285d9df --- /dev/null +++ b/code/using-std.cc @@ -0,0 +1,10 @@ +#include +using namespace std; + +int main() +{ + int a = 114, b = 514; + long long c = 1919, d = 810; + swap(a, b); // resolve to `std::swap` + swap(c, d); +} diff --git a/code/xchg1.c b/code/xchg1.c new file mode 100644 index 0000000..2c728c9 --- /dev/null +++ b/code/xchg1.c @@ -0,0 +1,12 @@ +void xchg(int *a, int *b) +{ + int t = *a; + *a = *b; + *b = t; +} + +int main() +{ + int a = 114, b = 514; + xchg(&a, &b); +} diff --git a/code/xchg2.cc b/code/xchg2.cc new file mode 100644 index 0000000..0a10e01 --- /dev/null +++ b/code/xchg2.cc @@ -0,0 +1,12 @@ +void xchg(int &a, int &b) +{ + int t = a; + a = b; + b = t; +} + +int main() +{ + int x = 114, y = 514; + xchg(x, y); +} diff --git a/code/xchg3.cc b/code/xchg3.cc new file mode 100644 index 0000000..e01e3de --- /dev/null +++ b/code/xchg3.cc @@ -0,0 +1,13 @@ +void xchg(int &a, int &b) +{ int t = a; a = b; b = t; } + +void xchg(long long &a, long long &b) +{ long long t = a; a = b; b = t; } + +int main() +{ + int x = 114, y = 514; + long long z = 1919, t = 810; + xchg(x, y); + xchg(z, t); +} diff --git a/code/xchg4.cc b/code/xchg4.cc new file mode 100644 index 0000000..bcb5cda --- /dev/null +++ b/code/xchg4.cc @@ -0,0 +1,15 @@ +template +void xchg(T &a, T &b) +{ + T t = a; + a = b; + b = t; +} + +int main() +{ + int x = 114, y = 514; + long long z = 1919, t = 810; + xchg(x, y); + xchg(z, t); +} diff --git a/theme b/theme new file mode 160000 index 0000000..979ef8c --- /dev/null +++ b/theme @@ -0,0 +1 @@ +Subproject commit 979ef8c8cae4fce78f47f50d779436f6e8d0e7ba