【NOI-题解】1389 - 数据分析1750 - 有0的数1457 - 子数整除1121 - “倒”数1962. 数值计算

文章目录

  • 一、前言
  • 二、问题
    • 问题:1389 - 数据分析
    • 问题:1750 - 有0的数
    • 问题:1457 - 子数整除
    • 问题:1121 - “倒”数
    • 问题:1962. 数值计算
  • 三、感谢

一、前言

本章节主要对循环中带余除法部分题目进行讲解,包括《1389 - 数据分析》《1750 - 有0的数》《1457 - 子数整除》《问题:1121 - “倒”数》《1962. 数值计算》《》题目。

二、问题

问题:1389 - 数据分析

类型:简单循环


题目描述:

该方法的操作方式为,如果要传递 2 个数字信息给友军,会直接传递给友军一个整数 n(n 是一个 10 位以内的整数),该整数的长度代表要传递的第一个数字信息,分解出该整数的每一位,如果该位是偶数,那么将这一位加到总和上去,代表要传递的第二个数字信息。
请你编写一个程序,从接收到的数字 n 中获取这 2 个数字信息。
比如:军事单位传递的数字为 12345678 ,则希望向友军传递的 2 个数字就是 8 (共有 8 位)和 20(2+4+6+8=20) 。

输入:

一个整数 n(n≤10^9 ) 。

输出:

两个整数,用空格隔开。

样例:

输入:

12345678

输出:

8 20

在这里插入图片描述


1.分析问题

  1. 已知:一个整数n;
  2. 未知:数字n中的 2 个数字信息。
  3. 关系:长度代表要传递的第一个数字信息,各数位上偶数的总和

2.定义变量

  • 定义整型变量n用于存储输入的整数,t作为临时变量存储n的每一位数字,one用于记录位数,two用于记录偶数位的总和。
	//二、数据定义 int n,t,one=0,two=0; 

3.输入数据

  • 读取用户输入的整数n。
	//三、数据输入 cin>>n;

4.数据计算
使用while(n)循环,只要n不为0就继续执行循环。

  • t = n % 10; 取n的个位数存入t。
  • if(t % 2 == 0) 判断t是否为偶数,如果是则执行two += t;累加到偶数总和中。
  • n /= 10; 通过整除10去除n的个位,使n的值向左移一位,以便下一次循环处理下一位数字。
  • ++one; 每次循环增加1,用于计数位数。
	//四、数据计算 while(n){t=n%10;if(t%2==0){two+=t;}n/=10;++one;	}

5.输出结果

  • 输出位数和偶数位数字的总和,中间用空格隔开。
	//五、输出结果 cout<<one <<" "<<two;

完整代码如下:

#include<bits/stdc++.h> // 引入头文件,包含了所有常用STL库函数,方便编程但可能降低编译速度,实际开发中推荐按需引入具体头文件。
using namespace std; // 声明使用标准命名空间std,使得可以直接调用std下的函数和对象,如cin, cout等,无需前缀std::。int main(){ // 定义主函数,程序的入口点。// 分析问题// 已知:一个整数n;// 未知:要找出两个关于n的信息——数字n的位数(长度)和n中所有偶数位数字的总和。// 数据定义int n, t, one = 0, two = 0; // 定义变量:n为待处理的整数,t为临时变量存储n的当前位数,one记录位数,two记录偶数位总和。// 数据输入cin >> n; // 从标准输入读取一个整数n。// 数据计算while(n){ // 当n不等于0时,继续循环。t = n % 10; // 取n的个位数存入t。if(t % 2 == 0){ // 判断t(当前位数)是否为偶数。two += t; // 若是偶数,将其加到two中。}n /= 10; // n除以10丢弃个位,让其变为下一个位的数。++one; // 位数计数加1,表示处理了一位。}// 输出结果cout << one << " " << two; // 打印出位数(one)和偶数位数字的总和(two),中间以空格分隔。return 0; // 主函数结束,返回0表示程序正常退出。
}

问题:1750 - 有0的数

类型:简单循环


题目描述:

请求出 1∼n 中含有数字 0 的数,有多少个?

输入:

一个整数 n(n≤999) 。

输出:

一个整数,代表 1∼n 中含有数字 0 的数的个数。

样例:

输入:

80

输出:

8

在这里插入图片描述


1.分析问题

  1. 已知:1-n的数 (n<=999);
  2. 未知:含0的数的个数;
  3. 关系:带余除法

2.定义变量

  • 定义整型变量n用于接收用户输入的上限值,c初始化为0,用来计数含0的数字数量。
	//二、数据定义 int n,c=0; 

3.输入数据

  • 从标准输入读取一个整数n,作为计数范围的上限。
	//三、数据输入 cin>>n;

4.数据计算

通过for循环遍历10到n(含n)之间的每个数i。

  • 判断条件i%10==0检查i的个位是否为0;
  • 判断条件i/10%10==0检查i的十位是否为0(先整除后取余,确保检查十位);
  • 如果i的个位或十位包含0,则c的值增加1,表示找到了一个含0的数字。
	//四、数据计算 for(int i=10;i<=n;i++){if(i%10==0||i/10%10==0) ++c;}

5.输出结果

  • 将统计得到的含0数字的数量c输出到标准输出。
	//五、输出结果 cout<<c;return 0;

完整代码如下:

#include<bits/stdc++.h> // 包含通用头文件,提供多种常用库函数
using namespace std; // 使用std命名空间,简化标准库函数的调用int main() { // 程序执行入口// 问题描述:// 给定一个正整数n,计算从1到n之间(包括n)数字中包含数字0的个数。// 方法:通过逐个检查每个数的个位和十位是否为0来计数。int n, count = 0; // 初始化变量,n为用户输入值,count记录含0的数的总数// 用户输入cin >> n; // 循环处理:从10开始至n(包括n)for(int i = 10; i <= n; i++) {// 检查当前数的个位或十位是否为0if(i % 10 == 0 || i / 10 % 10 == 0) count++; // 是,则count加1}// 输出结果cout << count; // 输出含0的数字总数return 0; // 程序成功执行完毕,返回0
}

问题:1457 - 子数整除

类型:循环应用


题目描述:

于一个五位数 abcde ,可将其拆分为三个子数:
sub1=abc
sub2=bcd
sub3=cde
例如,五位数20207 可以拆分成sub1=202
sub2=020 (也就是 20)
sub3=207
现在给定一个正整数 K ,要求你编程求出 10000 到30000 之间所有满足下述条件的五位数,条件是这些五位数的三个子数sub1,sub2,sub3 都可被 K 整除。

输入:

一个正整数K(0<K<1000) 。

输出:

每一行为一个满足条件的五位数,要求从小到大输出。
不得重复输出或遗漏。如果无解,则输出 No。

样例:

输入:

15

输出:

22555
25555
28555
30000

在这里插入图片描述


1.分析问题

  1. 已知:10000-30000的五位数,正整数K
  2. 未知:哪些五位数的三个子数sub1,sub2,sub3都可被K整除。
  3. 关系:一个五位数abcde,可将其拆分为三个子数:sub1=abc,sub2=bcd,sub3=cde

2.定义变量

  • 定义变量k用于存储用户输入的整数,sub1、sub2、sub3分别存储五位数分解出的三个子数。
  • isFind,表示是否找到了符合条件的数。
	//二、数据定义 int k,sub1,sub2,sub3; bool isFind=false;

3.输入数据

  • 读取用户输入的正整数K。
	//三、数据输入 cin>>k;

4.数据计算

通过一个for循环遍历从10000到30000的所有五位数。

  • 计算每个五位数对应的sub1、sub2、sub3,方法是通过数学运算提取相应位置的数字。

  • 判断这三个子数是否都能被K整除,如果能则打印该五位数,并设置isFind为true表示找到了至少一个解。

//四、数据计算 for(int i=10000;i<=30000;i++){sub1=i/100;sub2=i/10%1000;sub3=i%1000;if(sub1%k==0&&sub2%k==0&&sub3%k==0){if(!isFind) isFind=true;cout<<i<<endl;}	}

5.输出结果

  • 如果没有找到任何符合条件的数(即isFind仍为false),则输出"No"。
//五、输出结果 if(!isFind){cout<<"No";}

完整代码如下:

#include <bits/stdc++.h> // 包含常用头文件
using namespace std;int main() {// 问题分析:// 给定条件:寻找10000至30000之间,能被用户输入的正整数K整除其特定子串的所有五位数。// 子串定义:将五位数分为abcde,子串为abc、bcd、cde。// 数据定义int k, sub1, sub2, sub3; // k为用户输入的整数,sub1、sub2、sub3分别为五位数的子串bool isFind = false;     // 标记是否找到符合条件的五位数// 数据输入cin >> k; // 读取用户输入的K值// 数据计算for (int i = 10000; i <= 30000; i++) { // 遍历10000至30000之间的所有五位数sub1 = i / 100;                  // 提取五位数的前三位(abc)sub2 = (i / 10) % 1000;          // 提取五位数的中间三位(bcd),先除以10移除个位,再取模1000保留后三位sub3 = i % 1000;                 // 提取五位数的后三位(cde),直接对1000取余// 检查这三个子串是否都能被K整除if (sub1 % k == 0 && sub2 % k == 0 && sub3 % k == 0) {// 如果是第一个找到的解,标记已找到解if (!isFind) isFind = true;cout << i << endl; // 打印当前找到的满足条件的五位数}}// 输出结果// 如果没有找到任何满足条件的五位数if (!isFind) {cout << "No"; // 输出"No"}return 0; // 程序正常结束
}

问题:1121 - “倒”数

类型:需要找规律的循环


题目描述:

输入一个正整数 N(0<N<2147483647),将这个数倒着合成一个新数后输出。
比如: 543 ,倒过来是345 (请注意:34500 ,倒过来是543 ,不是00543 )!

输入:

一行,一个正整数 N 。

输出:

一行,一个正整数。

样例:

输入:

345

输出:

543

在这里插入图片描述


1.分析问题

  1. 已知:一个正整数n(0<n<2147483647);
  2. 未知:输出它的倒数;
  3. 关系:带余除法。

2.定义变量

  • 定义了两个整型变量,n用于存储输入的整数,result初始化为0,用于存放颠倒后的结果。
	//二、数据定义 int n,result=0;

3.输入数据

  • 通过cin读取用户输入的整数n。
	//三、数据输入 cin>>n;

4.数据计算

  • 使用while循环,在每次迭代中,将n的最后一个数字(通过n % 10获得)加到result的末尾(通过result * 10 + n % 10实现),同时去掉n的最后一个数字(通过n /= 10实现)。
  • 循环直至n变为0,此时result中存储的就是原数的数字顺序颠倒后的结果。
	//四、数据计算 while(n!=0){result=result*10+n%10;n/=10;}

5.输出结果

  • 使用cout输出结果result。
	//五、输出结果 cout<<result;

完整代码如下:

#include<iostream>
using namespace std;int main(){// 一、问题分析// 给定条件:一个正整数n,其值位于0到2147483647之间(不包括0)。// 目标:输出该整数的数字顺序颠倒后的结果。// 方法:使用带余数的除法逐步提取原数的每一位数字,并将其累加到结果变量以构建颠倒后的数字。// 二、数据定义int n, result = 0;  // n 用于存储输入的整数,result 初始化为0,用于存放最终的颠倒结果// 三、数据输入cin >> n;  // 从标准输入读取一个整数到变量n中// 四、数据计算while(n){  // 当n不为0时,继续处理result = result * 10 + n % 10;  // 将n的最后一个数字添加到result的末尾n /= 10;  // 去掉n的最后一个数字}// 五、输出结果cout  << result << endl;  // 输出颠倒后的数字return 0;  // 程序结束,返回0表示成功执行
}

问题:1962. 数值计算

类型:简单循环


题目描述:

给出一个不多于 5 位的非负整数,要求
1、 求出它是几位数
2、 分别输出每一位数字
3、 按逆序输出各位数字,例如原数为 321 ,应输出 123。

输入:

一个不大于 5 位的正整数。

输出:

三行
第 1 行 5 位数。
第 2 行 用空格分开的每个数字。
第 3 行 按逆序输出这个数。

样例:

输入:

12345

输出:

5
1 2 3 4 5
54321

在这里插入图片描述


1.分析问题

  1. 已知:一个不多于 5 位的非负整数;
  2. 未知:求出它是几位数; 分别输出每一位数字;按逆序输出各位数字;

2.定义变量

  • 定义了三个变量,n用于存储输入的整数,c用于计数位数,dx用于存储逆序整数。
	//二、数据定义 int n,c=0,dx=0;

3.输入数据

  • 使用cin读取用户输入的整数。
	//三、数据输入 cin>>n;

4.数据计算

  • 通过一个while循环处理输入的整数n。在循环中,我们递增c以计数位数,同时逐步构建逆序数dx。每次循环,temp除以10并向下取整,直到temp变为0,循环结束。
	int temp=n;while(temp){++c;dx=dx*10+temp%10;temp/=10;}

5.输出结果

  • 首先输出整数的位数c。
  • 接着,通过将dx(逆序数)逐位输出,实际上实现了原整数的正序输出。因为对逆序数dx从低到高逐位处理,恰好等同于原数的正序遍历。
  • 最后,再次输出逆序数dx。
//五、输出结果cout<<c<<endl; temp=dx;while(temp){cout<<temp%10<<" ";temp/=10;} cout<<endl<<dx;

完整代码如下:

#include <bits/stdc++.h> // 包含常用头文件,简化代码
using namespace std; // 使用std命名空间,避免std::前缀int main() {// 问题分析:// 给定一个最多5位的非负整数,需完成以下任务:// 1. 计算该整数的位数。// 2. 分别输出每一位数字(正序)。// 3. 按逆序输出每一位数字。// 数据定义:int n, c = 0, dx = 0; // n: 用户输入的整数; c: 记录位数; dx: 用于存储逆序后的整数// 数据输入:cin >> n; // 从标准输入读取一个非负整数// 数据处理:int temp = n; // 创建临时变量temp,用于迭代处理nwhile(temp) { // 当temp不为0时循环++c; // 每次循环增加c的值,用于计数位数dx = dx * 10 + temp % 10; // dx通过当前最低位数字构建逆序数(当前位*10+新低位)temp /= 10; // temp除以10丢弃当前最低位,继续处理下一位}// 输出结果:cout << c << endl; // 输出整数的位数// 准备正序输出数字,通过逆序数dx间接实现temp = dx; // 将dx的值赋给temp,开始正序输出每一位while(temp) { // 对temp进行循环,直到所有位都输出cout << temp % 10 << " "; // 输出当前最低位数字,然后加空格分隔temp /= 10; // 移动到下一个更高位}cout << endl; // 输出换行,分隔正序与逆序输出部分cout << dx << endl; // 再次输出dx,展示逆序后的整数return 0; // 程序正常结束
}

三、感谢

如若本文对您的学习或工作有所启发和帮助,恳请您给予宝贵的支持——轻轻一点,为文章点赞;若觉得内容值得分享给更多朋友,欢迎转发扩散;若认为此篇内容具有长期参考价值,敬请收藏以便随时查阅。

每一次您的点赞、分享与收藏,都是对我持续创作和分享的热情鼓励,也是推动我不断提供更多高质量内容的动力源泉。期待我们在下一篇文章中再次相遇,共同攀登知识的高峰!

在这里插入图片描述

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

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

相关文章

python数据分析-北京市二手住宅市场价格波动分析

一、研究背景&#xff1a; 北京市作为中国的首都和经济中心&#xff0c;房地产市场一直备受关注。二手住宅市场是房地产市场的重要组成部分&#xff0c;其价格波动不仅影响着购房者和卖房者的利益&#xff0c;也对整个经济社会的稳定和发展产生重要影响。因此&#xff0c;对北…

idea 配置文件中文乱码

再进行springboot项目开发时发现新建的配置文件中文注释乱码&#xff0c;如下: 处理办法: 1、打开idea&#xff0c;在 File 中找到 Settings,如下图 2、搜索 encodings 找到 File Encodings&#xff0c;如下图 3、将上图中圈上的地方全部改为 UTF-8 编码最后点击 Apply 应用即…

大数据同步方案怎么选,才能提高企业的业务效率?

大数据同步通常指的是在多个数据源或存储系统之间同步数据的过程&#xff0c;可以确保数据的一致性&#xff0c;提高数据的可用性和可靠性&#xff0c;同时支持数据分析和决策制定。 大数据同步的步骤通常包括&#xff1a; 数据识别&#xff1a;确定需要同步的数据类型和范围&…

爬虫-模拟登陆博客

import requests from bs4 import BeautifulSoupheaders {user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.132 Safari/537.36 } # 登录参数 login_data {log: codetime,pwd: shanbay520,wp-submit: …

eBay测评,自养号应该如何做?

测评自养号就是自己搭建国外的服务器和IP环境&#xff0c;实现自己注册eBay的买家账号&#xff0c;通过电脑端环境一台电脑就可以无限养号&#xff0c;一次可以开十几个窗口同时浏览下单&#xff0c;每个窗口都是独立的环境&#xff0c;一账号一环境一IP一卡 买家账号掌握在卖…

酷开科技丨酷开系统智慧中心,解锁AI智能家居生活的无限可能

想象一下&#xff0c;未来的AI电视不再是冷冰冰的机器&#xff0c;而是家庭的智能伙伴。它学习你的喜好&#xff0c;预测你的需求&#xff0c;用声音和触感与你交流。它控制家中的灯光、温度&#xff0c;甚至帮你订购生活用品。 在探索智能家居的未来发展时&#xff0c;酷开系…

Day01 数据结构概述

目录 一、数据结构概述 1、基本概念 2、数据结构 3、逻辑关系&#xff08;线性结构&非线性结构&#xff09; 4、物理结构&#xff08;存储结构&#xff09; 5、算法 6、算法特征 二、时空复杂度 1、时间复杂度 2、空间复杂度 3、结构类型 一、数据结构概述 1、…

FullCalendar日历组件集成实战(12)

背景 有一些应用系统或应用功能&#xff0c;如日程管理、任务管理需要使用到日历组件。虽然Element Plus也提供了日历组件&#xff0c;但功能比较简单&#xff0c;用来做数据展现勉强可用。但如果需要进行复杂的数据展示&#xff0c;以及互动操作如通过点击添加事件&#xff0…

记Windows环境下JDK安装配置

写在文章开头 这是笔者非常早期接触Java时写的文章&#xff0c;为方便每次系统重装时能够快速完成JDK解压版安装配置遂用此文记录了一下整个过程。 Hi&#xff0c;我是 sharkChili &#xff0c;是个不断在硬核技术上作死的 java coder &#xff0c;是 CSDN的博客专家 &#x…

springboot和mybatis项目学习

#项目整体样貌 ##bean package com.example.demo.bean;public class informationBean {private int id;private String name;private String password;private String attchfile;public int getId() {return id;}public String getName() {return name;}public String getPas…

基于Java技术的ERP管理系统:企业资源规划的先进解决方案

在当前数字化转型的趋势下&#xff0c;企业对于高效、稳定且具备扩展性的管理系统的需求日益增加。为了满足这一需求&#xff0c;我们开发了一款基于Java技术的鸿鹄ERP&#xff08;企业资源规划&#xff09;管理系统。该系统采用了Spring Cloud Alibaba、Spring Boot、MybatisP…

Unity Protobuf+RPC+UniTask

远程过程调用&#xff08;RPC&#xff09;协议详解 什么是RPC协议RPC的基本原理RPC的关键组件RPC的优缺点Protobuf函数绑定CallEncodeRecvDecodeSocket.Send和Recv项目地址 什么是RPC协议 远程过程调用&#xff08;Remote Procedure Call&#xff0c;简称RPC&#xff09;是一种…

WPF学习(1)--类与类的继承

在面向对象编程中&#xff0c;继承是一种机制&#xff0c;允许一个类&#xff08;称为子类或派生类&#xff09;从另一个类&#xff08;称为父类或基类&#xff09;继承属性和方法。继承使我们能够创建一个通用类&#xff0c;然后根据需要扩展或修改它以创建更具体的类。以下是…

适合小白学习的项目1832javaERP管理系统之成本管理Myeclipse开发mysql数据库servlet结构java编程计算机网页项目

一、源码特点 java 成本管理系统 是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助采用了serlvet设计&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统采用web模式&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发…

工作手机安全管理平台建设方案

第一章 项目背景 移动互联网的时代&#xff0c;各个行业在在推进移动办公和掌上办公&#xff0c;通过智能手机、平板电脑等进行线上办公&#xff0c;这样能提高了企业人员的办公效率&#xff0c;从而为客户提供更及时的服务。 在移动办公提高了工作人员办公效率的同时&#xf…

codegeex2-6b-int4 部署

codegeex2-6b-int4 模型文件 CodeGeeX2 仓库文件地址 CodeGeeX2 推理教程 conda create -n codegeex2 python3.10 -y conda activate codegeex2 pip install -r requirements.txt -i https://pypi.mirrors.u…

抓包工具 Wireshark 的下载、安装、使用、快捷键

目录 一、什么是Wireshark&#xff1f;二、Wireshark下载三、Wireshark安装四、Wireshark使用4.1 基本使用4.2 过滤设置1&#xff09;捕获过滤器2&#xff09;显示过滤器 4.3 过滤规则1&#xff09;捕获过滤器-规则语法2&#xff09;显示过滤器-规则语法 4.4 常用的显示过滤器规…

94. 二叉树的中序遍历(Swift实现, 迭代)

题目描述 使用迭代方法解题 class TreeNode {var val: Intvar left: TreeNode?var right: TreeNode?init(_ val: Int) {self.val valself.left nilself.right nil} }func inorderTraversal(_ root: TreeNode?) -> [Int] {var result [Int]() // 用于存储中序遍历…

kali中安装zsteg教程

1、下载文件 git clone http://www.github.com/zed-0xff/zsteg 2、第一步需要保证虚拟机是有网络的&#xff0c;不然无法克隆 3、可以将网络设置成如下后重启&#xff0c;访问百度看看能不能访问&#xff0c;若可以访问&#xff0c;则进行下一步 4、查看源&#xff0c;删除源&…

Python-程序流程控制

目录 1. 分支语句 1.1 if 1.2 if-else 1.3 if-elif-else 2. 循环语句 2.1 while 2.2 for 3.跳转语句 3.1 break 3.2 continue 1. 分支语句 1.1 if aint(input("请输入成绩")) if a>100:print ("牛逼") if a<60:print("不牛逼")1.2 if-e…