清华内部ACM培训资料,各类经典算法.docx
《清华内部ACM培训资料,各类经典算法.docx》由会员分享,可在线阅读,更多相关《清华内部ACM培训资料,各类经典算法.docx(55页珍藏版)》请在三一办公上搜索。
1、清华内部ACM培训资料,各类经典算法ACM小组内部预定函数 数学问题: 1.精度计算大数阶乘 4.精度计算加法 2.精度计算乘法 6.任意进制转换 数乘大数) 7.最大公约数、最小公倍数 5.精度计算减法 8.组合序列 12.求排列组合数 4.两点距离 8.判断线段与直线是否相交 12.Graham扫描法寻找凸包 4.求解模线性方程 9.快速傅立叶变换 10.Ronberg算法计算积分 11.行列式计算 字符串处理: 1.字符串替换 计算几何: 1.叉乘法求任意多边形面积 5.射向法判断点是否在多边形内部 9.点到线段最短距离 数论: 1.x的二进制长度 5.求解模线性方程组(中国余数定理)
2、图论: 1.Prim算法求最小生成树 排序/查找: 1.快速排序 数据结构: 2.字符串查找 2.求三角形面积 3.字符串截取 3.两矢量间角度 6.判断点是否在线段上 7.判断两线段是否相交 11.判断一个封闭图形是凹集还是凸集 3.模取幂运算 10.求两直线的交点 2.返回x的二进制表示中从低到高的第i位 6.筛法素数产生器 7.判断一个数是否素数 2.Dijkstra算法求单源最3.Bellman-ford算法求单4.Floyd算法求每对节点短路径 2.希尔排序 源最短路径 3.选择法排序 间最短路径 4.二分查找 1.顺序队列 5.二叉树 2.顺序栈 3.链表 4.链栈 一、数学问题
3、1.精度计算大数阶乘 语法:int result=factorial(int n); 参数: n: n 的阶乘 返回值: 阶乘结果的位数 注意: 本程序直接输出n!的结果,需要返回结果请保留long a 需要 math.h 源程序: int factorial(int n) long a10000; int i,j,l,c,m=0,w; a0=1; for(i=1;i=n;i+) c=0; for(j=0;j0) m+;am=c; w=m*4+log10(am)+1; printf(n%ld,am); for(i=m-1;i=0;i-) printf(%4.4ld,ai); return w;
4、 2.精度计算乘法 语法:mult(char c,char t,int m); 参数: c: 被乘数,用字符串表示,位数不限 t: 结果,用字符串表示 m: 乘数,限定10以内 返回值: null 注意: 需要 string.h 源程序: void mult(char c,char t,int m) int i,l,k,flag,add=0; char s100; l=strlen(c); for (i=0;il;i+) sl-i-1=ci-0; for (i=0;i=10) si=k%10;add=k/10;flag=1; else si=k;flag=0;add=0; if (flag)
5、l=i+1;si=add; else l=i; for (i=0;il;i+) tl-1-i=si+0; tl=0; 3.精度计算乘法 语法:mult(char a,char b,char s); 参数: a: 被乘数,用字符串表示,位数不限 b: 乘数,用字符串表示,位数不限 t: 结果,用字符串表示 返回值: null 注意: 空间复杂度为 o(n2) 需要 string.h 源程序: void mult(char a,char b,char s) int i,j,k=0,alen,blen,sum=0,res6565=0,flag=0; char result65; alen=strle
6、n(a);blen=strlen(b); for (i=0;ialen;i+) for (j=0;j=0;i-) for (j=blen-1;j=0;j-) sum=sum+resi+blen-j-1j; resultk=sum%10; k=k+1; sum=sum/10; for (i=blen-2;i=0;i-) for (j=0;j=i;j+) sum=sum+resi-jj; resultk=sum%10; k=k+1; sum=sum/10; if (sum!=0) resultk=sum;k=k+1; for (i=0;i=0;i-) si=resultk-1-i; sk=0; w
7、hile(1) if (strlen(s)!=strlen(a)&s0=0) strcpy(s,s+1); else break; 4.精度计算加法 语法:add(char a,char b,char s); 参数: a: 被乘数,用字符串表示,位数不限 b: 乘数,用字符串表示,位数不限 t: 结果,用字符串表示 返回值: null 注意: 空间复杂度为 o(n2) 需要 string.h 源程序: void add(char a,char b,char back) int i,j,k,up,x,y,z,l; char *c; if (strlen(a)strlen(b) l=strlen(
8、a)+2; else l=strlen(b)+2; c=(char *) malloc(l*sizeof(char); i=strlen(a)-1; j=strlen(b)-1; k=0;up=0; while(i=0|j=0) if(i0) x=0; else x=ai; if(j9) up=1;z%=10; else up=0; ck+=z+0; i-;j-; if(up) ck+=1; i=0; ck=0; for(k-=1;k=0;k-) backi+=ck; backi=0; 5.精度计算减法 语法:sub(char s1,char s2,char t); 参数: s1: 被减数,用
9、字符串表示,位数不限 s2: 减数,用字符串表示,位数不限 t: 结果,用字符串表示 返回值: null 注意: 默认s1=s2,程序未处理负数情况 需要 string.h 源程序: void sub(char s1,char s2,char t) int i,l2,l1,k; l2=strlen(s2);l1=strlen(s1); tl1=0;l1-; for (i=l2-1;i=0;i-,l1-) if (s1l1-s2i=0) tl1=s1l1-s2i+0; else tl1=10+s1l1-s2i+0; s1l1-1=s1l1-1-1; k=l1; while(s1k=0) tl1=
10、s1l1;l1-; loop: if (t0=0) l1=strlen(s1); for (i=0;il1-1;i+) ti=ti+1; tl1-1=0; goto loop; if (strlen(t)=0) t0=0;t1=0; 6.任意进制转换 语法:conversion(char s1,char s2,long d1,long d2); 参数: s: 原进制数字,用字符串表示 s2: 转换结果,用字符串表示 d1: 原进制数 d2: 需要转换到的进制数 返回值: null 注意: 高于9的位数用大写AZ表示,216位进制通过验证 源程序: void conversion(char s,
11、char s2,long d1,long d2) long i,j,t,num; char c; num=0; for (i=0;si!=0;i+) if (si=0) t=si-0; else t=si-A+10; num=num*d1+t; i=0; while(1) t=num%d2; if (t=9) s2i=t+0; else s2i=t+A-10; num/=d2; if (num=0) break; i+; for (j=0;ji/2;j+) c=s2j;s2j=si-j;s2i-j=c; s2i+1=0; 7.最大公约数、最小公倍数 语法:resulet=hcf(int a,i
12、nt b)、result=lcd(int a,int b) 参数: a: int a,求最大公约数或最小公倍数 b: int b,求最大公约数或最小公倍数 返回值: 返回最大公约数或最小公倍数 注意: lcd 需要连同 hcf 使用 源程序: int hcf(int a,int b) int r=0; while(b!=0) r=a%b; a=b; b=r; return(a); lcd(int u,int v,int h) return(u*v/h); 8.组合序列 语法:m_of_n(int m, int n1, int m1, int* a, int head) 参数: m: 组合数C的
13、上参数 n1: 组合数C的下参数 m1: 组合数C的上参数,递归之用 *a: 1n的整数序列数组 head: 头指针 返回值: null 注意: *a需要自行产生 初始调用时,m=m1、head=0 调用例子:求C(m,n)序列:m_of_n(m,n,m,a,0); 源程序: void m_of_n(int m, int n1, int m1, int* a, int head) int i,t; if(m1n1) return; if(m1=n1) for(i=0;im;i+) coutai ; / 输出序列 coutn; return; m_of_n(m,n1-1,m1,a,head);
14、/ 递归调用 t=ahead;ahead=an1-1+head;an1-1+head=t; m_of_n(m,n1-1,m1-1,a,head+1); / 再次递归调用 t=ahead;ahead=an1-1+head;an1-1+head=t; 9.快速傅立叶变换 语法:kkfft(double pr,double pi,int n,int k,double fr,double fi,int l,int il); 参数: prn: 输入的实部 pin: 数入的虚部 n,k: 满足n=2k frn: 输出的实部 fin: 输出的虚部 l: 逻辑开关,0 FFT,1 ifFT il: 逻辑开关,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 清华 内部 ACM 培训资料 各类 经典 算法
链接地址:https://www.31ppt.com/p-3635787.html