数控技术c语言直线、圆弧插补程序【研究分析】

上传人:8** 文档编号:168385299 上传时间:2022-11-09 格式:DOC 页数:3 大小:42KB
返回 下载 相关 举报
数控技术c语言直线、圆弧插补程序【研究分析】_第1页
第1页 / 共3页
数控技术c语言直线、圆弧插补程序【研究分析】_第2页
第2页 / 共3页
数控技术c语言直线、圆弧插补程序【研究分析】_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述
以下是直线差补c语言程序,后面还有圆弧差补,数控老师布置的作业,没办法,自己编的,运行时没问题,保证质量,#include #include main() int x, y,x2,y2,dx, dy, n, k, i, f,a; printf (请输入起始点:n);scanf(%d%d,&x,&y); printf(请输入终止点:n);scanf(%d%d,&x2,&y2); dx=abs(x2-x); dy=abs(y2-y); n=dx+dy;printf(步数n=%dn,n); if(x20) if(y20) k=1; else k=4; else if(y20) k=2; else k=3; printf(相限k=%dn,k); for (i=0,f=0;i= 0) switch (k) case 1:x+; printf(%d %dn,x ,y); f-=dy; continue; case 2:y+; printf(%d %dn,x,y); f-=dx; continue; case 3:x-; printf(%d %dn,x,y); f-=dy; continue; case 4:y-; printf(%d %dn,x,y); f-=dx; continue; else switch (k) case 1: y+; printf(%d %dn,x ,y); f+=dx; continue; case 2: x-; printf(%d %dn,x,y); f+=dy; continue; case 3:y-; printf(%d %dn,x,y); f+=dx; continue; case 4:x+; printf(%d %dn,x,y); f+=dy; continue; 下面为圆弧差补c语言程序#includestdio.h#includemath.h#includectype.hmain() int X0,Y0,Xe,Ye,a,I,J,Ie,Je,f; printf(请输入圆弧上的两个点:); scanf(%d %d %d %d,&X0,&Y0,&Xe,&Ye); printf(X0,Y0)=(%d,%d),(Xe,Ye)=(%d,%d),X0,Y0,Xe,Ye); printf(请选择圆弧加工方向,逆时针加工请输入1,顺时针加工请输入2n); scanf(%d,&a); I=X0,J=Y0,Ie=Xe,Je=Ye,f=0; switch(a) case 1: loop: while(Ie!=I)|(Je!=J) if(I=0&J0) if(f=0)f=f-2*I+1;I=I-1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f+2*J+1;J=J+1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop; if(I=0) if(f=0)f=f-2*J+1;J=J-1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f-2*I+1;I=I-1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop; if(I=0&J=0)f=f+2*I+1;I=I+1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f-2*J+1;J=J-1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop; if(I0&J=0)f=f+2*J+1;J=J+1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f+2*I+1;I=I+1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop; case 2: loop1: while(Ie!=I)|(Je!=J) if(I=0&J0) if(f=0)f=f-2*J+1;J=J-1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f+2*I+1;I=I+1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop1; if(I=0) if(f=0)f=f+2*I+1;I=I+1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f+2*J+1;J=J+1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop1; if(I=0&J=0)f=f+2*J+1;J=J+1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f-2*I+1;I=I-1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop1; if(I0&J=0)f=f-2*I+1;I=I-1;printf(f=%dI=%dJ=%dn,f,I,J); elsef=f-2*J+1;J=J-1;printf(f=%dI=%dJ=%dn,f,I,J);goto loop1; system(pause); 3技术l类别
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 模板表格


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!