欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-04-06 12:16:42
...

判断一个数是否为奇数

    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);

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

//代码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;
}

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

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

输入密码确认

#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();**则

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

加了

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

但还存在问题

C语言-分支语句和循环语句-练习题
修改代码为:

#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;
}

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

只打印字符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;
}

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

请问代码循环多少次(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;
}

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

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

#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;
}

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

给定两个数求最大公约数

#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;
}

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

打印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;
}

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

编写程序数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;
}

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

计算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;
}

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

猜数字游戏

  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;
}

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