【C语言编程之旅 6】刷题篇-for循环

第1题

在这里插入图片描述

解析

思路:
两个循环进行控制
外层循环控制打印多少行
内部循环控制每行打印多少个表达式以及表达式内容,
比较简单,具体参考代码

#include <stdio.h>
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;
}

在这里插入图片描述

第2题

在这里插入图片描述

解析

思路:

  1. 采用循环的方式输入一个数组
  2. 使用max标记数组中的最大值,采用循环的方式依次获取数组中的每个元素,与max进行比较,如果arr[i]大于 max,更新max标记的最大值,数组遍历结束后,max中保存的即为数组中的最大值。
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;
}

第3题

在这里插入图片描述

解析

#include<stdio.h>
int main() {double sum = 0;for (int i = 1; i <= 100; i++) {		 if (i % 2 != 0) {sum += 1.0 / i;}else {sum -= 1.0 / i;}}printf("%lf\n", sum);
}

方法2
思路:

  1. 从上述表达式可以分析出
    a. 该表达式主要由100项,基数项为正,偶数项为负
  2. 设置一个循环从1~100,给出表达式中的每一项:1.0/i, 注意此处不能使用1,否则结果全部为0
    然后使用flag标记控制奇偶项,奇数项为正,偶数项为负
    然后将所有的项相加即可
#include <stdio.h>int  main()
{int i = 0;double sum = 0.0;int flag = 1;for(i=1; i<=100; i++){sum += flag*1.0/i;flag = -flag;}printf("%lf\n", sum);return 0;
}

第4题

在这里插入图片描述

解析

思路:

  1. 给一个循环从1遍历到100,拿到每个数据后进行一下操作
  2. a. 通过%的方式取当前数据的个位,检测个位数据是否为9
    如果是,给计数器加1
    b. 通过/的方式取当前数据的十位,检测十位数据是否是9,
    如果是,给计数器加1
    循环一直继续,直到所有的数据检测完,所有9的个数已经统计在count计数中。
#include<stdio.h>
int main() {int count = 0;for (int i = 1; i <= 100; i++) {if (i%10 == 9) {  //控制个位count++;}if (i / 10 == 9) {  //控制十位count++;}}printf("%d\n", count);
}

第5题

在这里插入图片描述

解析

#include<stdio.h>
void menu() {printf("*********************\n");printf("*******1.play********\n");printf("*******0.exit********\n");}
void game() {//1.生成随机数int ret = rand() % 100 + 1;//2.猜数字while (1) {int guess = 0;printf("请输入你猜的数字:\n");scanf("%d", &guess);if (guess > ret) {printf("猜大了\n");}else if (guess < ret) {printf("猜小了\n");}else {printf("恭喜你猜对了!\n");break;}}
}
int main() {int input = 0;srand((unsigned int)time(NULL));do {menu();printf("请输入你的选择\n");scanf("%d", &input);switch (input) {case 1:game();break;case 0:printf("退出游戏\n");break;}} while (input);
}

第6题

在这里插入图片描述

解析

二分查找:
在一个有序的序列中,找某个数据是否在该集合中,如果在打印该数据在集合中的下标,否则打印找不到

具体找的方式:

  1. 找到数组的中间位置
  2. 检测中间位置的数据是否与要查找的数据key相等
    a: 相等,找到,打印下标,跳出循环
    b: key < arr[mid], 则key可能在arr[mid]的左半侧,继续到左半侧进行二分查找
    c: key > arr[mid], 则key可能在arr[mid]的右半侧,继续到右半侧进行二分查找
如果找到返回下标,否则继续,直到区间中没有元素时,说明key不在集合中,打印找不到

易错点:

  1. right的右半侧区间取值,该值决定了后序的写法
  2. while循环的条件是否有等号
  3. 求中间位置的方法,直接相加除2容易造成溢出
  4. 更改left和right的边界时,不确定是否要+1和-1

方法一,采用[left, right] 区间

#include <stdio.h>int main()
{int arr[] = {1,2,3,4,5,6,7,8,9,10};int key = 3;int left = 0;int right = sizeof(arr)/sizeof(arr[0])-1; // right位置的数据可以取到while(left<=right) // right位置有数据,必须要添加=号{int mid = left+(right-left)/2;if(arr[mid]>key) // key小于中间位置数据,说明key可能在左半侧,需要改变右边界{right = mid-1; // right位置的数据可以取到,因此right=mid-1}else if(arr[mid]<key)// key大于中间位置数据,说明key可能在右半侧,需要改变左边界{left = mid+1; // left位置的数据可以取到,因此left=mid+1}else{printf("找到了,下标是:%d\n", mid);break;}}if(left>right)printf("找不到\n");return 0;
}

方法二,采用[left, right) 区间

#include <stdio.h>int main()
{int arr[] = {1,2,3,4,5,6,7,8,9,10};int key = 3;int left = 0;int right = sizeof(arr)/sizeof(arr[0]); // right位置的数据取不到while(left<right) // right位置没有数据,此处不需要添加={int mid = left+(right-left)/2;if(arr[mid]>key) // key小于中间位置数据,说明key可能在左半侧,需要改变右边界{right = mid; // right位置的数据取不到,因此right=mid,不需要减1}else if(arr[mid]<key)// key大于中间位置数据,说明key可能在右半侧,需要改变左边界{left = mid+1; // left位置的数据可以取到,因此left=mid+1}else{printf("找到了,下标是:%d\n", mid);break;}}if(left>=right)printf("找不到\n");return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/418286.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mac 中vscode设置root启动

1. 找到你的vscode app&#xff0c;点击鼠标右键------->选项----->在访达中显示 2. 终端中输入以下命令&#xff0c;不要点回车&#xff0c;不要点回车&#xff0c;输入一个空格 sudo chflags uchg 3. 然后将你的程序拖到终端&#xff0c;会自动…

编译openjdk 调试java

背景 一直很想深入了解java运行机制&#xff0c;想编译debug版本openjdk 实践 安装环境 安装vmware软件&#xff0c;第一步就遇到很多麻烦&#xff0c;找不到免费的vmware。 后来下载了官网的&#xff0c;在github和百度一直搜如何破解&#xff0c;幸亏有大佬传了比较全的…

Peter算法小课堂—拓扑排序与最小生成树

拓扑排序 讲拓扑排序前&#xff0c;我们要先了解什么是DAG树。所谓DAG树&#xff0c;就是指“有向无环图”。请判断下列图是否是DAG图 第一幅图&#xff0c;它不是DAG图&#xff0c;因为它形成了一个环。第二幅图&#xff0c;它也不是DAG图&#xff0c;因为它没有方向。第三幅…

Docker Consul详解与部署示例

目录 Consul构成 Docker Consul 概述 Raft算法 服务注册与发现 健康检查 Key/Value存储 多数据中心 部署模式 consul-template守护进程 registrator容器 consul服务部署&#xff08;192.168.41.31&#xff09; 环境准备 搭建Consul服务 查看集群信息 registrato…

触摸屏监控双速电动机-确定地址分配

I/O地址分配 当选择了PLC之后&#xff0c;首先需要确定的是系统中各I/O点的绝对地址。在某些PLC 中1/O绝对地址的分配方式共有固定地址型、自动分配型、用户定义型3种。实际所使用的方式取决于所采用的PLC的CPU型号、编程软件、软件版本、编程人员的选择等因素。 本任务输入信…

vulnhub-dc2靶场

DC2 配置环境vmware17 nat网络配置 下载地址:DC and Five86 Series Challenges - DC-1 &#xff08;似乎从2024/1/18左右找不到这个资源了&#xff09; 攻击机kali与其在同一网段下 ip:192.168.52.130 信息收集 arp-scan -l #内网探测&#xff0c;扫描目标ip发现目标ip1…

vtk9.3 配置 visual studio 2019 运行环境 和运行实例详解

&#xff08;1&#xff09;包含文件配置&#xff1a; 项目--属性--VC目录&#xff0c;在包含目录中把include文件夹的地址加进去&#xff0c;一直要到下一级 vtk-9.3目录下&#xff0c; 小知识&#xff1a; 在Visual Studio 2019中运行项目时&#xff0c;如果项目中使用了第三…

Maven 基础安装配置及使用

大家好我是苏麟 , 今天聊聊Maven . Maven Maven , 是Apache公司下基于Java开发的开源项目 . 我们构建一个项目需要用到很多第三方的类库&#xff0c;需要引入大量的jar包。一个项目Jar包的数量之多往往让我们瞠目结舌&#xff0c;并且Jar包之间的关系错综复杂&#xff0c;一…

基于JavaWeb+SSM+Vue基于微信小程序生鲜云订单零售系统的设计和实现

基于JavaWebSSMVue基于微信小程序生鲜云订单零售系统的设计和实现 滑到文末获取源码Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 滑到文末获取源码 Lun文目录 目录 1系统概述 1 1.1 研究背景 1 1.2研究目的 1 1.3系统设计…

开源项目_大模型应用_Chat2DB

1 基本信息 项目地址&#xff1a;https://github.com/chat2db/Chat2DBStar&#xff1a;10.7K 2 功能 Chat2DB 是一个智能且多功能的 SQL 客户端和报表工具&#xff0c;适用于各种数据库。 对于那些平时会用到数据库&#xff0c;但又不是数据库专家的程序员来说&#xff0c;…

反序列化提升刷题(2)

今天的例题&#xff1a; <?phphighlight_file(__FILE__);class ctfshowvip{public $username;public $password;public $code;public function __construct($u,$p){$this->username$u;$this->password$p;}public function __wakeup(){if($this->username! || $thi…

springboot109新闻稿件管理系统

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的新闻稿件管理系统 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获…