目录
猜数字游戏
打印从大到小数字(a-c)
打印1-100中3的倍数
给两个数,求两个数的最大公约数
打印闰年(1000-2000)
打印100-200之间的素数
1-100直接带9的数字
计算1 / 1 - 1 / 2 + 1 / 3 - 1 / 4 + 1 / 5 …… + 1 / 99 - 1 / 100 的值,打印出结果
求10 个整数中最大值
9*9乘法表
?
猜数字游戏
猜数字游戏要求:
1.生成一个随机数字
2.猜数字(大、小、猜对了)
3.可以进行反复玩
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void menu()
{
printf("**********************************\n");
printf("*********** 1.play **********\n");
printf("*********** 0.exit **********\n");
printf("**********************************\n");
}
void game()
{
int guess = 0;
//1.生成随机数(1-100)
int ret = rand()%100+1;//使用rand之前要调用srand
//printf("%d\n", ret);
//2.猜数字
while (1)
{
printf("请猜数字:>");
scanf("%d", &guess);
if (guess < ret)
{
printf("猜小了\n");
}
else if (guess>ret)
{
printf("猜大了\n");
}
else
{
printf("猜对了\n");
break;
}
}
}
int main()
{
int input = 0;
//time函数获取时间戳
//设置随机数的生成起点
srand((unsigned int)time(NULL));//拿时间戳作为参数
do
{
//打印菜单
menu();
printf("请选择:>");
scanf("%d", &input);// 1 0
switch (input)
{
case 1:
game();//调用游戏函数
break;
case 0:
printf("退出游戏\n");
break;
default:
printf("选择错误,重新选择\n");
break;
}
} while(input);
return 0;
}
上面代码中最重要的是怎么样产生一个随机数,C语言中有专门产生随机数的函数就是rand,在使用rand函数之前要使用srand设置随机数的生成起点,在srand里面要用到time函数获取时间戳,这样rand产生的随机数每时每刻都是随机的。
打印从大到小数字(a-c)
int main()
{
int a = 0;
int b = 0;
int c = 0;
scanf("%d%d%d", &a, &b, &c);
if (a<b)
{
int x = a;
a = b;
b = x;
}
if (a<c)
{
int x = a;
a = c;
c = x;
}
if (b<c)
{
int x = b;
b = c;
c = x;
}
printf("a=%d b=%d c=%d\n", a, b, c);
return 0;
}
上面代码中要假设a是最大的,如果a比b或者c小就要进行交换,同理b和c也是这样。
打印1-100中3的倍数
int main()
{
int i = 1;
while (i <= 100)
{
if (i % 3 == 0)
{
printf("%d\n", i);
}
i++;
}
return 0;
}
给两个数,求两个数的最大公约数
方法1:辗转相除法
int main()
{
int a = 18;
int b = 24;
int c = 0;
while (c = a%b)
{
a = b;
b = c;
}
printf("%d\n", b);
return 0;
}
方法2:
int main()
{
int a = 0;
int b = 0;
scanf("%d%d", &a, &b);
int m = (a > b ? b : a);
while (1)
{
if (a%m == 0 && b%m == 0)
{
printf("%d", m);
}
m--;
}
}
打印闰年(1000-2000)
闰年:能被4整除不能被100整除是闰年并且能被400整除是闰年
int main()
{
int x = 1000;
while (x <= 2000)
{
if ((x % 4 == 0) && (x % 100 !=0))
{
printf("%d ", x);
}
if (x % 400 == 0)
{
printf("%d ", x);
}
x++;
}
return 0;
}
打印100-200之间的素数
int main()
{
int i = 0;
int count = 0;
for (i = 101; i <= 200; i++)
{
int j = 0;
for (j = 2; j<i; j++)
{
if (i%j == 0)
{
break;
}
}
if (j == i)
{
count++;
printf("%d ", i);
}
}
printf("\ncount = %d\n", count);
return 0;
}
素数是指只能被1或本身整除,要打印100-200直接的素数,首先要产生100-200直接的数字,然后让他们除以2到他们自己的数字。
可以对上面代码进行优化:
#include <math.h>
int main()
{
int i = 0;
int count = 0;
for (i = 101; i <= 200; i++)
{
int j = 0;
for (j = 2; j<sqrt(i); j++)
{
if (i%j == 0)
{
break;
}
}
if (j == i)
{
count++;
printf("%d ", i);
}
}
printf("\ncount = %d\n", count);
return 0;
}
1-100直接带9的数字
int main()
{
int i = 0;
int count = 0;
for (i = 1; i <= 100; i++)
{
if (i % 10 == 9 )
{
count++;
}
if(i / 10 == 9)
{
count++;
}
}
printf("%d\n", count);
return 0;
}
带9的数字各位就是取余如果等于9就是个位带9,十位就是除以10等于9就是十位带9。
计算1 / 1 - 1 / 2 + 1 / 3 - 1 / 4 + 1 / 5 …… + 1 / 99 - 1 / 100 的值,打印出结果
int main()
{
int i = 0;
double sum = 0;
int flag = 1;
for (i = 1; i <= 100; i++)
{
sum += flag*(1.0 / i);
flag = -flag;
}
return 0;
}
求10 个整数中最大值
int main()
{
int arr[10] = { 0 };
int i = 0;
int max = 0;
for (i = 0; i<10; i++)
{
scanf("%d", &arr[i]);
}
//
max = arr[0];
for (i = 1; i<10; i++)
{
if (arr[i]>max)
max = arr[i];
}
printf("max = %d\n", max);
return 0;
}
假设最大数是第一个,然后让第一个分别与后面比较得到最大值。
9*9乘法表
int main()
{
int i = 0;
//控制行数
for (i = 1; i <= 9; i++)
{
//打印每一行内容,每行有i个表达式
int j = 0;
for (j = 1; j <= i; j++)
{
printf("%d*%d=%2d ", i, j, i*j);
}
printf("\n");
}
return 0;
}
?
|