当前位置: 首页 > news >正文

鹏哥C语言49-51---第6次作业:循环语句 for 和 while

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
//-----------------------------------------------------------------------------------------------第六次作业:for循环等
//-------------------------------------------------------------------------6.1.单选
/*
题目名称:
关于while(条件表达式)循环体,以下叙述正确的是 ( B )?
(假设循环体里面没有break,continue,return,goto等等语句)

题目内容:
A.循环体的执行次数总是比条件表达式的执行次数多一次
B.条件表达式的执行次数总是比循环体的执行次数多一次
C.条件表达式的执行次数与循环体的执行次数一样
D.条件表达式的执行次数与循环体的执行次数无关
*/

//-------------------------------------------------------------------------6.2.单选
//#include <stdio.h>
/*
int main()
{
        int a = 0, b = 0;
        for (a = 1, b = 1; a <= 100; a++)
        {
              if (b >= 20) break;
              if (b % 3 == 1)
              {
                  b = b + 3;
                  continue;  //跳过 本次循环后边的代码,直接去调整代码
              }
              b = b - 5;
         }
        printf("%d\n", a);
        return 0;
}
*/
//程序的输出结果是 ? ( a= 8 )
//题目内容 :

//---------------------------------------------------------------------------------6.3. 编程题:数9的个数
//编写程序数一下1-100所有整数中出现多少个数字9
// 9 19 29 39 49 59 69 79 89 99
// 91 92 93 94 95 96 97 98 99
// 一共20个9
/*
int main()
{
    int i = 0;
    int count = 0;
    for (i = 1; i <= 100; i++)
    {
        //判断个位是不是9
        if (i % 10 == 9)
        {
            count++;
        }
        //判断十位是不是9
        if (i / 10 == 9)
        {
            count++;
        }
    }
    printf("count=%d", count);
    return 0;
}
*/


//---------------------------------------------------------------------------------6.4. 编程题:分数求和
//计算1/1-1/2+1/3-1/4+1/5...... + 1 / 99 - 1 / 100的值, 打印出结果

/*------------------------------------------------------自写版
int main()
{
    int i = 0;
    float sum = 0;
    for (i = 1; i <= 100; i++)
    {
        if (i % 2 == 1)
        {
            sum = sum + 1.0 / i; 
         //sum = sum + 1/ i;   // -----------自写版 :错误示范  1/3=0 余1
        }
        if (i % 2 == 0)
        {
            sum = sum - 1.0 / i;
        }
    
    }
    printf("%f", sum); 
    return 0;
}
*/

/*------------------------------------------------------教学版
int main()
{
    int i = 0;
    float sum = 0;
    int flag = 1;
    for (i = 1; i <= 100; i++)
    {
        sum = sum + flag*(1.0 / i); //尽量不写判断,避免浪费
        flag = -flag;
    }
    printf("%f", sum);
    return 0;
}
*/

//---------------------------------------------------------------------------------6.5. 编程题:求最大值
//求10个数中最大值
//----------------------------------------------------自写版,没问题
/*
int main()
{
    //给10个整数----整型数组
    //int arr[10] = { 12,21,13,44,35,67,47,8,19,10 }; //不一定有序,不能用二分查找
    
    //自己输入 10 个 数值
    int arr[10] = { 0 };
    // int arr[] = { 0 }; // 意思就是只有一个元素 0
   // 如果不指定元素个数,就默认初始化了几个元素,就几个元素
    int n = 0;
    for (n = 0; n <= 9; n++)
    {
        scanf("%d", &arr[n]);
    }
    //找最大值
    int max = arr[0]; // 假设 第一个数 是最大值
    int i = 0;
    for (i = 1; i <= 9; i++)
    {
        if (arr[i] >= max)
            max = arr[i];
    }
    printf("%d\n", max);
    return 0;
}
*/

//---------------------------------------------------------------------------------6.6. 编程题:乘法口诀表
//在屏幕输出乘法口诀表

//--------------------------------------------------------- 教学版
//在屏幕上输出9*9乘法口诀表
//1*1=1
//2*1=2 2*2=4
//3*1=3 3*2=6 3*3=9
// ....
/*
int main()
{
    int i = 0;
    int sum = 0;
    for (i = 1; i <= 9; i++)
    {
        int j = 0;
        for (j = 1; j <= i; j++)
        {
            sum = i * j;
            //printf("%d*%d=%2d ", i, j, sum); //自动填充两位 ,右对齐
            printf("%d*%d=%-2d ", i, j, sum); //自动填充两位 ,左对齐

        }
        printf("\n");
    }

    return 0;
}
*/


//---------------------------------------------------------------------------------6.7. 编程题:猜数字游戏 
//1.设计菜单页
//2.用户做选择
//3.系统给出随机数
//4.用户猜数字
//5.判断是否猜对,如果猜对了说''恭喜你猜对了,就是***''则结束,如果没有猜对,则提示''猜大了'' ''猜小了'',继续猜

/*
//-------------------准备进入游戏
void game()
{
  // 1.系统生成一个随机数(这块还不太理解)
    srand((unsigned int)time(NULL));//生成随机数的起点
    int ret = rand() % 100 + 1;//生成随机数 ret 0--100
    // printf("%d", ret);   // 查看生成数是不是随机数
  
  // 2.用户输入数字
    int input = 0;
  // 3.判断''猜大了'' ''猜小了''(没猜对就循环猜)
    while(1)
    {
        printf("请猜数字:>");
        scanf("%d", &input);
        if (input < ret)
            printf("猜小了");
        else if (input > ret)
            printf("猜大了");
        else
        {
            printf("恭喜你猜对了!就是%d", input);
            break;
        }
    }

}

int main()
{
    
    //1.设计菜单页
    printf("------------------1.猜数字-------------------\n");
    printf("------------------0.退出游戏-----------------\n");
    //2.用户选择是否进入游戏
    printf("请选择:>");
    while(1)
    {
        int select = 0;
        scanf("%d", &select);
        if (select == 1)
        {
            printf("------------------进入游戏-------------------\n");
            game(); // 3. 进入游戏开始猜数字---调用函数
            break;
        }
        else if (select == 0)
        {
            printf("------------------退出游戏-------------------");
            break;
        }
        else
        {
            printf("选择错误,请重新输入:>");
        }
    }

    return 0;
}
*/

//---------------------------------------------------------------------------------6.8. 编程题:二分查找(折半算法)
//编写代码在一个整形有序数组中查找具体的某个数
//要求:找到了就打印数字所在的下标, 找不到则输出 : 找不到。
#include <string.h>
/*
int main()
{
    //给一个整形有序数组
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    //给定要查的数
    int num = 0; 
    scanf("%d", &num);
    //查找
    int left = 0;
    int sz = sizeof(arr) / sizeof(arr[0]);
    int right = sz - 1;

    while(left<=right)
    {
        int mid = (left + right) / 2;
        if (num < arr[mid])
        {
            right=mid-1;
        }
        else if (num > arr[mid])
        {
            left=mid+1;
        }
        else
        {
            printf("找到了,下标是:%d", mid);
            break;
        }
    }

    if (left > right)
    {
        printf("找不到");

    }

    return 0;
}
*/

http://www.lryc.cn/news/444894.html

相关文章:

  • springboot中药材进存销管理系统
  • GitHub上图像超分开源项目推荐【持续更新】
  • 浅谈软件测试的基础知识(1)
  • Mac 上哪个剪切板增强工具比较好用? 好用剪切板工具推荐
  • 基于opencv的车牌检测和识别系统(代码+教程)
  • list(二) (list模拟实现)
  • [Linux]从零开始的泰山派系统安装与远程教程
  • Python国产新 ORM 框架 fastzdp_sqlmodel 快速入门教程
  • 面试速通宝典——3
  • 每天一个数据分析题(四百七十三)- 元数据
  • 产品经理面试整理-练习常见面试问题
  • 一步到位的智慧:BI可视化大屏在复杂环境中如何精准拾取目标
  • 前端开发迎来新机会,全栈转型就靠这个!
  • 关于less的基本使用
  • python 将 aac 转为 mp3,保持原有目录结构
  • 考研数据结构——C语言实现折半查找
  • 【游戏引擎】C++自制游戏引擎 Lunar Game Engine
  • 使用【Sa-Token】实现Http Basic 认证
  • layui table中的checkbox禁用问题
  • 102.SAPUI5 sap.ndc.BarcodeScannerButton调用摄像头时,localhost访问正常,使用IP访问失败
  • 20240923软考架构-------软考186-190答案解析
  • 基于Spring Boot的宠物咖啡馆平台【附源码】
  • C++模拟实现list:list、list类的初始化和尾插、list的迭代器的基本实现、list的完整实现、测试、整个list类等的介绍
  • Offer60:n个骰子的点数
  • 几种常见的索引类型扫描
  • 苹果CMS插件:优化蜘蛛访问内容,提升百度收录率
  • 后端开发刷题 | 没有重复项数字的全排列
  • Python中的“打开与关闭文件”:从入门到精通
  • 9.23 My_string.cpp
  • 【android10】【binder】【3.向servicemanager注册服务】