C语言-分支语句和循环语句-练习题

判断一个数是否为奇数

    int num;
    printf("输入一个数:");
    scanf("%d", &num);

    if (0 == num % 2) // 判断这个数除以 2 的余数
        printf("%d 是偶数。", num);
    else
        printf("%d 是奇数。", num);

输出1-100之间的奇数

    int i = 1;
    while (i <= 100)
    {
        if (num & 1) // 判断这个数最后一位是1这为奇数
        printf("%d ", num);
        i++;
    }

从小到大输出三个数

#include <stdio.h>
int main()
{
    int a = 0, b = 0, c = 0;
    scanf("%d%d%d", &a, &b, &c);
    //算法实现a>b >c
    if (a < b)
    {
        int tmp = a;
        a = b;
        b = tmp;
    }
    if (a < c)
    {
        int tmp = a;
        a = c;
        c = tmp;
    }
    if (b < c)
    {
        int tmp = b;
        b = c;
        c = tmp;
    }
    printf("%d %d %d\n", a, b, c);
    return 0;
}

打印1-100之间所有3的倍数的数字

#include <stdio.h>
int main()
{
    int i = 0;
    for (i = 1; i <= 100; i++)
    {
        if (i % 3 == 0)
        {
            printf("%d ", i);
        }
    }
    return 0;
}

判断m\n的打印结果(switch)

   int n = 1;
   int m = 2;
   switch (n)
   {
   case 1:  //没有break,符合case 1 完成case 1 继续执行case 2……
       m++; //m=3,n=1
   case 2:
       n++; //m=3,n=2
   case 3:
       switch (n)
       {       //switch允许嵌套使用
       case 1: //未执行
           n++;
       case 2: //符合,执行,break,继续执行case 4
           m++;
           n++; //m=4,n=3
           break;
       }
   case 4:
       m++; //m=5,n=3
       break; //跳出 switch
   default: //未执行
       break;
   }
   printf("m = %d, n = %d\n", m, n); //m = 5, n = 3

getchar()

int ch = getchar(); //getchar 接收键盘一个字符
putchar(ch); //putchar 输出
printf("%c", ch);

在这里插入图片描述

//代码1
#include <stdio.h>
int main()
{
    int ch = 0;
    //ctrl+z获取一个EOF -end of file->-1
    while ((ch = getchar()) != EOF) //直接输入EOF不会停止,读入一个字符在写一个字符,EOF是三个字符
        putchar(ch);
    return 0;
}

在这里插入图片描述

在这里插入图片描述

输入密码确认

#include <stdio.h>
int main()
{
    int ret = 0;
    char password[20] = {0};
    printf("请输入密码:"); //输入缓冲区:123456\n
    scanf("%s", password);  //输入密码,存放在password数组中
    //缓冲区还剩余一个\n,\n-->10
    // printf("%d", '\n'); //10
    getchar(); //读取\n
    printf("请确认(Y/N)?");
    ret = getchar(); //Y /N
    if (ret == 'Y')
    {
        printf("确认成功\n");
    }
    else
    {
        printf("放弃确认\n");
    }
    return 0;
}

若不加中间的**getchar();**则

在这里插入图片描述

加了

在这里插入图片描述

但还存在问题

在这里插入图片描述
修改代码为:

#include <stdio.h>
int main()
{
    int ret = 0;
    int ch = 0;
    char password[20] = {0};
    printf("请输入密码:"); //输入缓冲区:123456\n
    scanf("%s", password);  //输入密码,存放在password数组中
    //缓冲区还剩余一个\n,\n-->10
    // printf("%d", '\n'); //10
    // getchar(); //读取\n
    while ((ch = getchar()) != '\n')
    {
        ; //空语句
    }
    printf("请确认(Y/N)?");
    ret = getchar(); //Y /N

    if (ret == 'Y')
    {
        printf("确认成功\n");
    }
    else
    {
        printf("放弃确认\n");
    }
    printf("密码为:%s\n", password);
    return 0;
}

在这里插入图片描述

只打印字符0-9,否则跳走(while)

//代码2
#include <stdio.h>
int main()
{
    int ch = 0;
    //ctrl+z获取一个EOF -end of file->-1
    while ((ch = getchar()) != EOF)
    {
        if (ch < '0' || ch > '9') //只打印字符0-9,否则跳走
            continue;
        putchar(ch);
        printf("\n");
    }
    return 0;
}

在这里插入图片描述

请问代码循环多少次(for)

//请问循环要循环多少次?
#include <stdio.h>
int main()
{
    int i = 0;
    int k = 0;
    for (i = 0, k = 0; k = 0; i++, k++)
        //k=0,把0赋值为k,这个表达式的结果为k的值,即为0,为假,所以循环0次
        k++;
    for (i = 0, k = 0; k = 1; i++, k++) //k=1,2……不等于0,为真,死循环
        k++;
    return 0;
}

计算 n的阶乘或计算 1!+2!+3!+……+10!

#include <stdio.h>
int main()
{
    int ret = 1, ret2 = 0;
    int n = 0;
    printf("请输入n:\n");
    scanf("%d", &n);
    int i = 1;
    for (i = 1; i <= n; i++)
    {
        ret = ret * i;
        ret2 = ret2 + ret;
    }
    printf("%d!=%d\n", n, ret); //计算 n的阶乘。
    printf("1!+2!+……+%d!=%d", n, ret2); //1!+2!+……+n!
    return 0;
}

在一个有序数组中查找具体的某个数字n。

#include <stdio.h>
int main()
{
    int v[] = {1, 3, 6, 7, 9, 10, 12, 13, 16, 19};
    int k = 7;
    int i = 0;
    int sz = sizeof(v) / sizeof(int);
    //折半查找log2n
    int left = 0;       //左下表
    int right = sz - 1; //右下标
    int mid = 0;
    while (left <= right)
    {
        mid = (left + right) / 2;
        if (v[mid] > k)
        {
            right = mid - 1;
        }
        else if (v[mid] < k)
        {
            left = mid + 1;
        }
        else
            break;
    }
    if (left <= right)
        printf("找到了,下标是%d\n", mid);
    else
        printf("找不到\n");
    //时间复杂度为O(n)
    // for (i = 0; i < sz; i++)
    // {
    //     if (k == v[i])
    //     {
    //         printf("找到了,下标是%d\n", i);
    //         break;
    //     }
    // }
    // if (sz == i)
    // {
    //     printf("未找到");
    // }
    return 0;
}

编写int binsearch(int x, int v[], int n);

功能:在v[0]<=v[1]<=v[2]<= ….<=v[n-1]的数组中查找x.

//如果实现一个二分查找函数:
int bin_search(int arr[], int left, int right, int key)
{
    int mid = 0;
    while (left <= right)
    {
        mid = (left + right) >> 1;
        if (arr[mid] > key)
        {
            right = mid - 1;
        }
        else if (arr[mid] < key)
        {
            left = mid + 1;
        }
        else
            return mid; //找到了,返回下标
    }
    return -1; //找不到
}

编写代码,演示多个字符从两端移动,向中间汇聚。

#include <string.h>
#include <windows.h>
#include <stdlib.h>
#include <stdio.h>
int main()
{
    //welcome to China!!!!!!
    //######################
    //w####################!
    //we##################!!
    // ……
    char arr1[] = "welcome to China!!!!!!"; //以\0未结束
    char arr2[] = "######################";
    int left = 0;
    //int right = sizeof(arr1) / sizeof(arr1[0]) - 2;
    int right = strlen(arr1)-1;
    while (left<= right)
    {
        arr2[left] = arr1[left];
        arr2[right] = arr1[right];
        printf("%s\n", arr2);
        //休息1秒
        Sleep(1000);
        system("cls");//执行系统命令的一个函数-cls-清空屏幕
        left++;
        right--;
    }
    printf("%s\n", arr2);
    return 0;
}

在这里插入图片描述

编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则提示登录成,如果三次均输入错误,则退出程序。

#include <string.h>
#include <stdio.h>
int main()
{
    int i = 0;
    char password[20] = {0};
    for (i = 0; i < 3; i++)
    {
        printf("请输入密码:>");
        scanf("%s", password);
        // if (password == "123456")//== 不能用来比较两个字符串是否相等,应该使用一个库函数-strcmp
        if (strcmp(password, "123456") == 0)
        {
            printf("登录成功\n");
            break;
        }
        else
        {
            printf("密码错误\n");
        }
    }
    if (i == 3)
        printf("三次密码均错误,退出程序\n");
    return 0;
}

在这里插入图片描述

给定两个数求最大公约数

#include <stdio.h>
int main()
{
    int m = 0;
    int n = 0;
    int r = 0;
    scanf("%d%d", &m, &n);
    //辗转相除法
    while (r = m % n) //余数 4%6=4 6%4=2
    {
        m = n;
        n = r;
    }
    printf("%d\n", n);
    return 0;
}

打印1000-2000之间的闰年

#include <stdio.h>
int main()
{
    int i = 0;
    int count = 0;
    for (i = 1000; i <= 2000; i++)
    {
        //判断year 是否为闰年
        // 1. 能被4整除,且不能被100整除的是闰年
        // 2. 能被400整除是闰年
        // if (i % 4 == 0 && i % 100 != 0)
        // {
        //     count++;
        //     printf("%d ", i);
        // }
        // else if (i % 400 == 0)
        // {
        //     count++;
        //     printf("%d ", i);
        // }
        if ((i % 4 == 0 && i % 100 != 0) || i % 400 == 0)
        {
            count++;
            printf("%d ", i);
        }
    }
    printf("\ncount=%d\n", count);
    return 0;
}

在这里插入图片描述

打印100-200之间的素数《素数求解的n种境界》

#include <math.h>
#include <stdio.h>
int main()
{
    int i = 0;
    int count = 0;
    //sqrt - 开平方的数学库函数
    for (i = 101; i <= 200; i += 2) //排除所有偶数
    {
        //判断i是否为素数
        //素数判断的规则
        //1. 试除法: 产生2->i-1
        // i=a*b    a和b中至少有一个数字≤开平方i
        int j = 0;
        for (j = 2; j <= sqrt(i); j++) //i/2也是对的
        {
            if (i % j == 0)
            {
                break;
            }
        }
        if (j > sqrt(i))
        {
            count++;
            printf("%d ", i);
        }
    }
    printf("\ncount=%d\n", count);
    return 0;
}

在这里插入图片描述

编写程序数1-100所有整数中出现多少个数字9

#include <stdlib.h> //itoa所需要的库函数
#include <stdio.h>
int main()
{
    int i = 0;
    int j = 0;
    int count = 1;
    for (i = 1; i <= 100; i++)
    {
        // //法一:
        // if (i % 10 == 9)
        // {
        //     count++;
        // }
        // if (i / 10 == 9)
        // {
        //     count++;
        // }
        //法二:使用itoa函数
        char s[10] = {0};
        itoa(i, s, 10); // itoa(int,char,要转换的进制数)
        for (j = 0; j < strlen(s); j++)
        {
            if (s[j] == '9')
            {
                count++;
                printf("%d ", i);
                break;
            }
        }
    }
    printf("\ncount=%d\n", count);
    return 0;
}

在这里插入图片描述

计算1/1-1/2+1/3-1/4……-1/100

#include <stdio.h>
int main()
{
    int i = 0;
    double re = 0;
    // int flag = 1;
    // for (i = 1; i <= 100; i++)
    // {
    //     re = re + flag * (1.0 / i);
    //     flag = flag * (-1);
    // }
    for (i = 1; i <= 100; i += 2)
    {
        re = re + 1.0 / i;
    }
    for (i = 2; i <= 100; i += 2)
    {
        re = re - 1.0 / i;
    }
    printf("%lf", re);
    return 0;
}

求10个整数的最大值

#include <stdio.h>
int main()
{
    int arr[] = {1, 23, 4, 5, 6, 7, 32, 13, 33, 54};
    int i = 0;
    int max = arr[0]; //如果max=0,则无法判断负数
    for (i = 1; i < sizeof(arr) / sizeof(arr[0]); i++)
    {
        if (arr[i] > max)
        {
            max = arr[i];
        }
    }
    printf("max=%d\n", max);
    return 0;
}

乘法口诀表

#include <stdio.h>
int main()
{
    int i = 0, j = 0;
    for (i = 1; i < 10; i++)
    {
        for (j = 1; j <= i; j++)
        {
            printf("%d * %d = %-2d  ", j, i, i * j); //不够两位补空格
        }
        printf("\n");
    }
    return 0;
}

在这里插入图片描述

猜数字游戏

  1. 电脑会生成一个随机数
  2. 猜数字

注:

时间戳:当前计算机时间-计算机的起始时间(1970.1.1.0:0:0)=(xxxx)秒
rand() RAND_MAX-32767
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void menu()
{
    printf("**********************************\n");
    printf("***********  1.play     **********\n");
    printf("***********  0.exit     **********\n");
    printf("**********************************\n");
}
//TDD-测试驱动开发。
//RAND_MAX--rand函数能返回随机数的最大值。
void game()
{
    //生成随机数
    int random_num = rand() % 100 + 1; //1-100之间的
    int input = 0;                     //接收猜的数字
    while (1)
    {
        printf("请输入猜的数字>:");
        scanf("%d", &input);
        if (input > random_num)
        {
            printf("猜大了\n");
        }
        else if (input < random_num)
        {
            printf("猜小了\n");
        }
        else
        {
            printf("恭喜你,猜对了\n");
            break;
        }
    }
}
int main()
{
    int input = 0;
    srand((unsigned)time(NULL)); //拿时间戳设置一个随机起点,设置一次就可以,不要频繁调用
    do
    {
        menu();
        printf("请选择>:");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            game();
            break;
        case 0:
            printf("退出游戏!\n");
            break;
        default:
            printf("选择错误,请重新输入!\n");
            break;
        }
    } while (input);
    return 0;
}

在这里插入图片描述

  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

eeenkidu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值