c语言好玩的编程代码,C语言函数的编程代码

1,C语言函数的编程代码#includevoid func();void main()func();}void func()printf(“函数func被调用~\n”);}问题详细点???你想要什么?用c语言结构体链表很好实现,用纯数组也可以,用c++类也可以,主要是写这代码有点长!不然就帮你写了!
2,趣味C语言小编程题眼就是求出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; }
3,趣味C语言小编程题眼就是求出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;}}#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【c语言好玩的编程代码,C语言函数的编程代码】
4,有什么好玩的C语言小程序2048小游戏#include<stdio.h>#include<stdlib.h>#include<conio.h>#include<time.h>#include<windows.h>intjsk( );//计算空格数void rsgm( );//重置游戏void inkey( );//按键输入void left( );//向左移动void right( );//向右移动void up( );//向上移动void down( );//向下移动void show( );//输出界面void adnum( ); //添加随机数void yes( );//游戏是否结束(1是0否)void gtxy(int x, int y); //控制光标位置的函数int a[4][4];//存储16个格子中的数字int score = 0;//每局得分int best = 0;//最高得分int ifnum;//是否需要添加数字(1是0否)int over;//游戏结束标志(1是0否)int i,j,k;int main( ) //重置游戏 inkey( );//按键输入 return 0;}void setColor(unsigned short ForeColor = 7, unsigned short BackGroundColor = 0)SetConsoleTextAttribute(handle, ForeColor + BackGroundColor * 0x10);}//用于控制字符颜色的函数void rsgm( )//重置游戏int n = rand( ) % 16;//随机函数产生0-15的数字 for (i = 0; i < 4; i++)elseelse}} adnum( ); system("cls"); CONSOLE_CURSOR_INFO cursor_info= SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE),&cursor_info); setColor(14, 0);//设置字体淡红色,背景为黑色printf("\n\n\t\t2048小游戏"); setColor(7, 0);//恢复白字黑底printf("\n\t┌──────┬──────┬──────┬──────┐");printf("\n\t│││││");printf("\n\t├──────┼──────┼──────┼──────┤");printf("\n\t│││││");printf("\n\t├──────┼──────┼──────┼──────┤");printf("\n\t│││││");printf("\n\t├──────┼──────┼──────┼──────┤");printf("\n\t│││││");printf("\n\t└──────┴──────┴──────┴──────┘");show( );}void show( )//输出界面for(j=0;j<4;j++)if(a[i][j]==0)else if(a[i][j]<10)else if (a[i][j] == 4)else if (a[i][j] == 8)printf("%d", a[i][j]); setColor(7, 0); printf("│");}else if (a[i][j] < 100)else if (a[i][j] == 32)else if (a[i][j] == 64)printf("%d", a[i][j]); setColor(7, 0); printf("│");}else if (a[i][j] < 1000)else if (a[i][j] == 256)else if (a[i][j] == 512)printf("%d ", a[i][j]); setColor(7, 0); printf("│");}else if (a[i][j] < 10000)elseprintf(" %d ", a[i][j]); setColor(7, 0); printf("│");}}if (jsk( ) == 0)printf("\n\n游戏结束!是否继续? [ Y/N ]:");}}}void inkey( )//按键输入while (1)if (over)elseif (key == 78|| key == 110)elsecontinue; }ifnum = 0;if(key==224)key=getch( );switch (key)case 77: right( ); break;case 72: up( ); break;case 80: down( );break;}if (score > best)if (ifnum)}}int jsk( )//计算空格数 for (i = 0; i < 4; i++)return n;}void left( )//向左移动score = score + 2 * a[i][j];a[i][j] = 0;ifnum = 1; }else if ( a[i][k] == 0)elsek++; }}}}}void right( )//向右移动else if ( a[i][k] == 0)else}}}}void up( )//向上移动a[j][i] = 0; ifnum = 1; }else if ( a[k][i] == 0)elsek++; }}}}}void down( )//向下移动else if (a[k][i] == 0)elseif ((k - 1) != j)}}}}void adnum( )//添加随机数for (int i = 0; i < 4; i++)elseif (k == 0 || k == 1)else}}}}void yes( )//游戏是否结束}over = 1;}void gtxy(int x, int y)//控制光标位置的函数coord.X = x;coord.Y = y;SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), coord);}

    推荐阅读