C语言趣味编程100例,趣味编程

1,趣味编程先定义一个数组,存储原来的数据,从数组的第一位开始,每拿掉一张,就把该位置零,下一位与最后一位掉换,其余位向前覆盖,直到直剩一张为止.#include <stdio.h>void main()int a[100];//定义数组int i,m,n,j,temp;printf("Enter n:");//输入有多少张scanf("%d",&n);if(n==1) printf("the last is:1");//1张2张就直接给出来了else if(n==2) printf("the last is:2");elsefor(i=0;i<n;i++)a[i]=i+1;printf("%3d ",a[i]);//给数组赋值,就相当于编号了}printf("\n");i=0;doa[i]=0;//拿掉一张,该位置就空了,置为0;j=i+1;while(j<n-1)//后位进一,空位的下一位移到最后if(j==i+1) temp=a[j];a[j]=a[j+1];if(j==n-2) a[j+1]=temp;j++;}if(a[n-2]==0) break;//还剩一张了i++;for(m=0;m<n;m++)//这个循环语句是用来观察每一步,以验证结果if(a[m]==0) continue;printf("%3d ",a[m]);}printf("\n");}while(1);printf("The last is:%d\n",a[n-1]);//最后一张的编号}}用TC2.0编译通过,希望能帮到你.如果想知道答案请加我微信号:lovehhqd 我是比较懂这方面的亓琢排
2,经典C语言程序例子题目01:在一个已知的字符串中查找最长单词,假定字符串中只含字母和空格,空格用来分隔不同的单词 。直接编译,程序执行结果如下图所示:题目02:编写一个int string_len(char *s),返回字符串s的字符长度(不包括\0) 。直接编译,程序执行结果如下图所示:扩展资料:C语言是一门通用计算机编程语言,应用广泛 。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言 。尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台 。
3,经典c语言程序100例第一题#include <stdio.h>main() int i,j,k; printf("\n"); for(i=1;i<5;i++)for(j=1;j<5;j++)for(k=1;k<5;k++)if(i!=k&&i!=j&&j!=k)printf("%d,%d,%d\n",i,j,k);}}vc木有错1.#includevoid main(){ double x,y; printf("请输入x的值:"); scanf("lf",&x); while(x<1.79769e+308||x>2.22507e-308){ if(x>=1.79769e+308&&x<=2.22507e-308){ break; } printf("不正确的x输入!"); printf("\n\n"); printf("请输入x的值:"); scanf("lf",&x); } if(x<1){ y=x; }else if(1<=x&&x<10){ y=2*x-1; }else{ y=3*x-1; } printf("y的值是:%.2f",y); } 2. #include void main(){ int num[4],i,j,temp; for(i=1;i<4;i++){ printf("请输入第%d个数:",(i+1)); scanf("%d",&num[i]); } for(i=0;i<4;i++){ for(j=0;j<3-i;j++){ if(num[j]>num[j+1]){ temp=num[i]; num[i]=num[i+1]; num[i+1]=temp; } } } pirntf("这4个数从小到大的顺序是:"); for(i=0;i<4;i++){ printf("%d ",num[i]); } }【C语言趣味编程100例,趣味编程】
4,单片机c语言编程100个实例51单片机C语言编程实例 基础知识:51单片机编程基础 单片机的外部结构: 1. DIP40双列直插; 2. P0 , P1,P2,P3四个8位准双向I/O引脚;(作为I/O输入时,要先输出高电平) 3. 电源VCC(PIN40)和地线GND(PIN20); 4. 高电平复位RESET(PIN9);(10uF电容接VCC与RESET,即可实现上电复位) 5. 内置振荡电路,外部只要接晶体至X1(PIN18)和X0(PIN19);(频率为主频的12倍) 6. 程序配置EA(PIN31)接高电平VCC;(运行单片机内部ROM中的程序) 7. P3支持第二功能:RXD、TXD、INT0、INT1、T0、T1 单片机内部I/O部件:(所为学习单片机,实际上就是编程控制以下I/O部件,完成指定任务) 1. 四个8位通用I/O端口,对应引脚P0、P1、P2和P3; 2. 两个16位定时计数器;(TMOD,TCON,TL0,TH0,TL1 , TH1) 3. 一个串行通信接口;(SCON , SBUF) 4. 一个中断控制器;(IE,IP) 针对AT89C52单片机,头文件AT89x52.h给出了SFR特殊功能寄存器所有端口的定义 。C语言编程基?。?1. 十六进制表示字节0x5a:二进制为01011010B;0x6E为01101110 。2. 如果将一个16位二进数赋给一个8位的字节变量,则自动截断为低8位,而丢掉高8位 。3. ++var表示对变量var先增一;var—表示对变量后减一 。4. x |= 0x0f;表示为 x = x | 0x0f; 5. TMOD = ( TMOD & 0xf0 ) | 0x05;表示给变量TMOD的低四位赋值0x5,而不改变TMOD的高四位 。6. While( 1 ); 表示无限执行该语句,即死循环 。语句后的分号表示空循环体,也就是{;} 在某引脚输出高电平的编程方法:(比如P1.3(PIN4)引脚) 代码 1. #include <AT89x52.h> //该头文档中有单片机内部资源的符号化定义,其中包含P1.3 2. void main( void ) //void 表示没有输入参数,也没有函数返值 , 这入单片机运行的复位入口 3. { 4. P1_3 = 1; //给P1_3赋值1,引脚P1.3就能输出高电平VCC 5. While( 1 ); //死循环,相当 LOOP: goto LOOP; 6. } 注意:P0的每个引脚要输出高电平时,必须外接上拉电阻(如4K7)至VCC电源 。在某引脚输出低电平的编程方法:(比如P2.7引脚) 代码 1. #include <AT89x52.h> //该头文档中有单片机内部资源的符号化定义,其中包含P2.7 2. void main( void ) //void 表示没有输入参数,也没有函数返值,这入单片机运行的复位入口 3. { 4. P2_7 = 0; //给P2_7赋值0 , 引脚P2.7就能输出低电平GND 5. While( 1 ); //死循环,相当 LOOP: goto LOOP; 6. } 在某引脚输出方波编程方法:(比如P3.1引脚) 代码 1. #include <AT89x52.h> //该头文档中有单片机内部资源的符号化定义,其中包含P3.1 2. void main( void ) //void 表示没有输入参数,也没有函数返值 , 这入单片机运行的复位入口 3. { 4. While( 1 ) //非零表示真,如果为真则执行下面循环体的语句 5. { 6. P3_1 = 1; //给P3_1赋值1,引脚P3.1就能输出高电平VCC 7. P3_1 = 0; //给P3_1赋值0,引脚P3.1就能输出低电平GND 8. } //由于一直为真 , 所以不断输出高、低、高、低……,从而形成方波 9. } 将某引脚的输入电平取反后,从另一个引脚输出:( 比如 P0.4 = NOT( P1.1) ) 代码 1. #include <AT89x52.h> //该头文档中有单片机内部资源的符号化定义 , 其中包含P0.4和P1.1 2. void main( void ) //void 表示没有输入参数,也没有函数返值 , 这入单片机运行的复位入口 3. { 4. P1_1 = 1; //初始化 。P1.1作为输入,必须输出高电平 5. While( 1 ) //非零表示真,如果为真则执行下面循环体的语句 6. { 7. if( P1_1 == 1 ) //读取P1.1,就是认为P1.1为输入,如果P1.1输入高电平VCC 8. { P0_4 = 0; } //给P0_4赋值0,引脚P0.4就能输出低电平GND 2 51单片机C语言编程实例 9. else //否则P1.1输入为低电平GND 10. //{ P0_4 = 0; } //给P0_4赋值0,引脚P0.4就能输出低电平GND 11. { P0_4 = 1; } //给P0_4赋值1,引脚P0.4就能输出高电平VCC 12. } //由于一直为真,所以不断根据P1.1的输入情况,改变P0.4的输出电平 13. } 将某端口8个引脚输入电平 , 低四位取反后,从另一个端口8个引脚输出:( 比如 P2 = NOT( P3 ) ) 代码 1. #include <AT89x52.h> //该头文档中有单片机内部资源的符号化定义,其中包含P2和P3 2. void main( void ) //void 表示没有输入参数,也没有函数返值,这入单片机运行的复位入口 3. { 4. P3 = 0xff; //初始化 。P3作为输入,必须输出高电平,同时给P3口的8个引脚输出高电平 5. While( 1 ) //非零表示真,如果为真则执行下面循环体的语句 6. { //取反的方法是异或1,而不取反的方法则是异或0 7. P2 = P3^0x0f //读取P3,就是认为P3为输入,低四位异或者1 , 即取反 , 然后输出 8. } //由于一直为真,所以不断将P3取反输出到P2 9. } 注意:一个字节的8位D7、D6至D0,分别输出到P3.7、P3.6至P3.0,比如P3=0x0f,则P3.7、P3.6、P3.5、P3.4四个引脚都输出低电平,而P3.3、P3.2、P3.1、P3.0四个引脚都输出高电平 。同样,输入一个端口P2,即是将P2.7、P2.6至P2.0,读入到一个字节的8位D7、D6至D0 。第一节:单数码管按键显示 单片机最小系统的硬件原理接线图: 1. 接电源:VCC(PIN40)、GND(PIN20) 。加接退耦电容0.1uF 2. 接晶体:X1(PIN18)、X2(PIN19) 。注意标出晶体频率(选用12MHz),还有辅助电容30pF 3. 接复位:RES(PIN9) 。接上电复位电路,以及手动复位电路,分析复位工作原理 4. 接配置:EA(PIN31) 。说明原因 。发光二极的控制:单片机I/O输出 将一发光二极管LED的正极(阳极)接P1.1,LED的负极(阴极)接地GND 。只要P1.1输出高电平VCC,LED就正向导通(导通时LED上的压降大于1V) , 有电流流过LED,至发LED发亮 。实际上由于P1.1高电平输出电阻为10K,起到输出限流的作用,所以流过LED的电流小于(5V-1V)/10K = 0.4mA 。只要P1.1输出低电平GND,实际小于0.3V,LED就不能导通 , 结果LED不亮 。开关双键的输入:输入先输出高 一个按键KEY_ON接在P1.6与GND之间,另一个按键KEY_OFF接P1.7与GND之间,按KEY_ON后LED亮,按KEY_OFF后LED灭 。同时按下LED半亮,LED保持后松开键的状态,即ON亮OFF灭 。代码 1. #include <at89x52.h> 2. #define LED P1^1 //用符号LED代替P1_1 3. #define KEY_ON P1^6 //用符号KEY_ON代替P1_6 4. #define KEY_OFF P1^7 //用符号KEY_OFF代替P1_7 5. void main( void ) //单片机复位后的执行入口,void表示空,无输入参数,无返回值 6. { 7. KEY_ON = 1; //作为输入,首先输出高,接下KEY_ON,P1.6则接地为0,否则输入为1 8. KEY_OFF = 1; //作为输入 , 首先输出高,接下KEY_OFF,P1.7则接地为0 , 否则输入为1 9. While( 1 ) //永远为真,所以永远循环执行如下括号内所有语句 10. { 11. if( KEY_ON==0 ) LED=1; //是KEY_ON接下,所示P1.1输出高 , LED亮 12. if( KEY_OFF==0 ) LED=0; //是KEY_OFF接下,所示P1.1输出低,LED灭 13. } //松开键后,都不给LED赋值,所以LED保持最后按键状态 。14. //同时按下时,LED不断亮灭,各占一半时间,交替频率很快,由于人眼惯性,看上去为半亮态 15. } 数码管的接法和驱动原理 一支七段数码管实际由8个发光二极管构成,其中7个组形构成数字8的七段笔画,所以称为七段数码管 , 而余下的1个发光二极管作为小数点 。作为习惯,分别给8个发光二极管标上记号:a,b,c,d,e,f,g,h 。对应8的顶上一画,按顺时针方向排,中间一画为g,小数点为h 。我们通常又将各二极与一个字节的8位对应,a(D0),b(D1),c(D2),d(D3),e(D4),f(D5),g(D6),h(D7),相应8个发光二极管正好与单片机一个端口Pn的8个引脚连接,这样单片机就可以通过引脚输出高低电平控制8个发光二极的亮与灭,从而显示各种数字和符号;对应字节 , 引脚接法为:a(Pn.0),b(Pn.1),c(Pn.2),d(Pn.3),e(Pn.4) , f(Pn.5) , g(Pn.6),h(Pn.7) 。如果将8个发光二极管的负极(阴极)内接在一起,作为数码管的一个引脚 , 这种数码管则被称为共阴数码管,共同的引脚则称为共阴极,8个正极则为段极 。否则 , 如果是将正极(阳极)内接在一起引出的,则称为共阳数码管,共同的引脚则称为共阳极,8个负极则为段极 。以单支共阴数码管为例,可将段极接到某端口Pn,共阴极接GND , 则可编写出对应十六进制码的七段码表字节数据5,C语言编程100例变形题#include "stdio.h" #include "conio.h" main()int i,j,k;printf("\n");for(i=1;i<5;i++) /*以下为三重循环*/for(j=1;j<5;j++)for (k=1;k<5;k++)if (i!=k&&i!=j&&j!=k) /*确保i、j、k三位互不相同*/printf("%d,%d,%d\n",i,j,k);}getch()}#include#includeint n=15;int main(){ int i,j,k,m,n; int g[n][n]; printf("input the odd number(number<=15) you want !\n"); scanf("%d",&m); if((m>0)&&(m%2)){ printf("your intput number is %d\n",m); n=m*m; j=0; k=m/2; for(i=1;i<=n;i++) { g[j][k]=i; if(i%m==0) if(j==m-1) j=0; else j++; else { if(j==0) j=m-1; else j--; if(k==m-1) k=0; else k++; } } for(i=0;i#include "stdio.h"#include "conio.h"main() int i,j,k; printf("\n"); for(i=0;i<=8;i++) /*以下为三重循环*/for(j=0;j<=8;j++)for (k=0;k<=8;k++)if(i!=1&&i!=2&&i!=4&&i!=5&&j!=6&&j!=1&&j!=2&&j!=4&&j!=5&&k!=6&&k!=1&&k!=2&&k!=4&&k!=5&&k!=6)if (i!=k&&i!=j&&j!=k)/*确保i、j、k三位互不相同*/printf("%d,%d,%d\n",i,j,k);}}getch();}6,趣味C语言小编程#include <stdio.h>#include <conio.h>void main()int i,j,n;scanf("%d",&n);for(i=0;i<n;++i)for(j=n-1;j>i;--j) printf(" "); for(j=0;j<2*i+1;++j) printf("*"); printf("\n");}getch();}调试通过的程序代码如下:#include <stdio.h> main() int i; for (i=9;i<7000;i+=2) if (i%10==9 && i%9==8 && i%8==7 && i%7==6 && i%6==5 && i%5==4 && i%4==3 && i%3==2) printf("%d\n",i); }上面的程序运行结果如下:25195039题眼就是求出2~10的最小公倍数,然后减一 。模拟排队的算法是可行的,但不是最优的 。#include <stdio.h> int od(int x,int n) //x是否能被n整除,是返回1,否返回0 if (x%n) return 0; return 1; } int gbs(int a[],int n) //求a[n]内所有元素的最小公倍数 int i,j,k,o,m=0; int b[20],c[100]; for (i=0;i<n;i++) if(m<a[i]) m=a[i]; b[i]=a[i]; } j=2; o=0; while (j<=m) k=0; for (i=0;i<n;i++)if (od(b[i],j)) k++; if (k>1) break; } if(k>1) c[o++]=j; for (i=0;i<n;i++) if (od(b[i],j)) b[i]=b[i]/j; m=0; for (i=0;i<n;i++) if(m<b[i]) m=b[i]; } else j++; } k=1; for(i=0;i<o;i++) k*=c[i]; } for (i=0;i<n;i++) k*=b[i]; } return k; } main() int a[10]; for(int i=1;i<=10;i++) a[i-1]=i; printf("count=%d\n",gbs(a,10)-1); getchar(); return 0; }很简单,写一个暴力枚举 。但注意一下细节可以省很多时间:1 循环每次增10,因为最后一位一定是9.2 无需判断2,3,4,因为之前已经判断了6,8;6,8分别是3和2,4的倍数 。#include<iostream>using namespace std;int main()for(int i=19;i<=6999;)if((i+1)%9==0&&(i+1)%8==0&&(i+1)%7==0&&(i+1)%6==0&&(i+1)%5==0)cout<<i<<" ";i+=10;}}楼主你的方法不见得最简单!如果限制不是7000,而是更大 。那你的效率会越来越低!试试我的!#include<stdio.h>#include<math.h>void main() int minNum; int sum = 2;//sum表示前面N个数的最小公倍数,初始为2的公倍数 , 即为2for(int i =3; i<=10; i++)//后续的数为3~10, 首先取2 , 3的最小公倍数,为6,再取6 , 4的最小公倍数minNum = sum>i?i:sum;for(int k=minNum; k>1; k--)if(sum%k==0 && i%k==0)//取两个数的最大公约数break;}sum = sum * i / k;//两个数的乘机除以最大公约数==两个数的最小公倍数} while(sum<7000) printf("result: %d\n", sum-1);sum *= 2;//以2的倍数增加,小于7000继续循环 }}这个问题还是比较简单的,思路如下:首先要写一个判断程序,判断当前的正整数是否除2—10都缺1,然后从0到7000依次判断,不断的调用这个函数,如果成功就输出人数并跳出循环 。代码如下:#include<iostream.h>int Que(int i,int n) int flag=1; for(int j=2;j<=n;j++)if((i+1)%j)flag=0;break;} } return flag;}void main() for(int i=0;i<7000;i++)if(Que(i,10))cout<<"人数为:"<<i<<endl;break;}}

    推荐阅读