【NOI-题解】1108 - 正整数N转换成一个二进制数1290 - 二进制转换十进制1386 - 小丽找半个回文数1405 - 小丽找潜在的素数?

文章目录

  • 一、前言
  • 二、问题
    • 问题:1108 - 正整数N转换成一个二进制数
    • 问题:1290 - 二进制转换十进制
    • 问题:1386 - 小丽找半个回文数
    • 问题:1405 - 小丽找潜在的素数?
  • 三、感谢

一、前言

本章节主要对进制转换的题目进行讲解,包括《1108 - 正整数N转换成一个二进制数》《1290 - 二进制转换十进制》《1386 - 小丽找半个回文数》《1386 - 小丽找半个回文数》题目。

二、问题

问题:1108 - 正整数N转换成一个二进制数

类型:进制转换


题目描述:

输入一个不大于 32767 的整数 n ,将它转换成一个二进制数。

输入:

输入只有一行,包括一个整数 (0 ≤ n ≤ 32767)。

输出:

输出只有一行。

样例1:

输入:

100

输出:

1100100

样例2:

输入:

0

输出:

0

在这里插入图片描述


1.分析问题

  1. 已知:一个不大于 32767 的整数 n。
  2. 未知:将它转换成一个二进制数。
  3. 关系:进制转换

2.定义变量

  • n; 用于存储待转换的整数。
  • v; 用于存储转换后的二进制位,每个元素代表一位,0 或 1。
	//二、定义变量(已知、未知、关系) int n;vector<int> v; 

3.输入数据

  • 从标准输入读取一个整数。
	//三、输入已知cin>>n;

4.数据计算

  • 使用while(n)循环,当n不为0时执行循环体。
  • 取n的当前最低位(n % 2),将其添加到vector的末尾。
  • 将n右移一位,相当于除以2并向下取整,继续处理下一位。
//四、根据关系计算while(n){v.push_back(n%2);n/=2;}

5.输出结果

  • 在转换完成后,先检查vector是否为空。若为空,则直接输出0。
  • 否则,从vector的末尾开始遍历到开头,逐个输出vector中的元素,即得到了该整数的二进制表示。
//五、输出未知 if(v.empty()){cout<<0;}else{for(int i=v.size()-1;i>=0;i--){cout<<v[i];}}return 0;

完整代码如下:

#include<bits/stdc++.h> // 包含通用头文件,提供所有常用的标准库功能
using namespace std;    // 使用标准命名空间std,简化代码中的库函数调用int main() {            // 程序入口点// 一、分析问题// 目标:将一个不大于32767的十进制整数转换为二进制表示// 二、定义变量int n;               // 存储用户输入的整数vector<int> v;       // 使用vector来存储整数的二进制位,每个元素代表一位(0或1)// 三、输入cin >> n;            // 从标准输入读取一个整数n// 四、转换过程while(n) {           // 当n非零时执行循环v.push_back(n % 2); // 取n的当前最低位(n除以2的余数),加入到vector末尾n /= 2;           // n右移一位,即n除以2并向下取整,继续处理下一位}// 五、输出// 检查vector是否为空(理论上这里可以直接输出"0",因为当n为0时,循环不会执行,直接进入此逻辑)if(v.empty()) {cout << 0;       // 如果vector为空(即输入的n为0),直接输出"0"} else {// 遍历vector,从最后一个元素开始向前遍历,输出二进制位for(int i = v.size() - 1; i >= 0; i--) {cout << v[i]; // 输出当前位}}// 结束程序return 0;            // 主函数正常结束,返回0
}

问题:1290 - 二进制转换十进制

类型:进制转换、字符串


题目描述:

请将一个 25 位以内的 2 进制正整数转换为 10 进制!

输入:

一个 25 位以内的二进制正整数。

输出:

该数对应的十进制。

样例:

输入:

111111111111111111111111

输出:

16777215

在这里插入图片描述


1.分析问题

  1. 已知:一个 25 位以内的 2 进制正整数;
  2. 未知:转换为 10 进制;
  3. 关系:二进制转十进制。

2.定义变量

  • s 用于存储输入的二进制。
  • res 初始化结果变量,用于存放转换后的十进制数值。
	//二、定义变量(已知、未知、关系)string s;int res=0; 

3.输入数据

  • 从标准输入读取一个二进制字符串。
	//三、输入已知cin>>s;

4.数据计算

  • 使用一个循环遍历输入字符串s的每一个字符(从末位到首位)。
  • 初始化一个变量t用于记录当前位的权重,初始为1(即2^0)。
  • 将当前字符(‘0’或’1’)减去字符’0’得到其对应的整数值(0或1),然后乘以当前位的权重t,累加到结果res中。
  • 在每次迭代后,将权重t乘以2,以便处理下一位的二进制位。
	//四、根据关系计算int t=1;for(int i=s.size()-1;i>=0;i--){res+=(s[i]-'0')*t;t*=2;}

5.输出结果

  • 输出转换后的十进制数值。
//五、输出未知 cout<<res;

完整代码如下:

#include <bits/stdc++.h> // 包含头文件,提供了所有常用的标准库功能
using namespace std;    // 使用标准命名空间std,简化代码中的库函数调用int main() {            // 程序入口点// 一、问题分析// 已知条件:一个长度不超过25位的二进制正整数// 目标:将此二进制数转换为十进制数// 二、变量定义string s;           // 存储二进制字符串int res = 0;        // 初始化转换结果为0// 三、输入二进制cin >> s;           // 从标准输入读取一个二进制// 四、二进制转十进制计算int t = 1;          // 初始化当前位的权重为2^0 = 1for(int i = s.size() - 1; i >= 0; i--) { // 从字符串末位开始遍历到首部// 将字符数字('0'或'1')转换为其对应的整数值(0或1),然后乘以其权重t,累加到res中res += (s[i] - '0') * t;// 每处理完一位,权重t翻倍,相当于下一位的权重(2^n)t *= 2;}// 五、输出十进制结果cout << res;         // 输出转换得到的十进制数return 0;            // 主函数正常结束,返回0
}

问题:1386 - 小丽找半个回文数

类型:进制转换


题目描述:

小丽同学在编程中学到了回文数的概念,如果一个数正过来读和反过来读是同一个数,那么这个数就是回文数;比如:2、5、8、66、121、686、12321 都是回文数,小丽发现,这样的数不算多。

于是小丽有个想法,如果这个数不是回文数,但这个数在 2 进制或者 16 进制下是回文数,就算这个整数是半个回文数,比如 417 并不是回文,但 417 对应的 16 进制数是 1A1 是回文数,因此 417 算半个回文数。

请你编程帮助小丽找符合条件的半个回文数。

输入:

第一行是一个整数 n(5≤n≤100); 第二行是 n 个整数(这些整数都是 [0,10^8] 之间的整数);

输出:

所有符合条件的半个回文数,每行一个。

样例:

输入:

5
121 417 27 100 21

输出:

417
27
21

在这里插入图片描述


1.分析问题

  1. 已知:n个整数;
  2. 未知:找符合条件的半个回文数。
  3. 关系:这个数不是回文数,但这个数在 2 进制或者 16 进制下是回文数,就算这个整数是半个回文数

2.定义变量

	int n;string s,binary,hexa;

3.输入数据

  • 程序接收用户输入的整数数量n。
	//三、输入已知cin>>n;
  • 随后,对于每一个输入的整数s,程序先检查它是否为回文数,如果是则跳过(因为它不符合“半个回文数”的定义)。
	for(int i=0;i<n;i++){cin>>s;}
  • 接着,将s分别转换为二进制和十六进制形式,并检查这两种形式是否为回文。只要其中任一是回文,就输出原始的整数s。
		if(checkHW(s)) continue;//四、根据关系计算binary=decbin(s);hexa=dechex(s);//五、输出未知 if(checkHW(binary)||checkHW(hexa)){cout<<s<<endl;}

4.数据计算

  • 此函数通过创建字符串的逆序副本并比较两者是否相等来判断给定字符串是否为回文。
bool checkHW(string t){string re=t;reverse(re.begin(),re.end());return t==re;
}
  • 将输入的十进制字符串转换为二进制。
string decbin(string dec){int ndec=0,t;char c;string bin;for(int i=0;i<dec.size();i++){ndec=ndec*10+(dec[i]-'0');}while(ndec){t=ndec%2;c=t+'0';bin=c+bin;ndec/=2;}return bin;
}
  • 将输入的十进制字符串转换为十六进制字符串

string dechex(string  dec){int ndec=0,t;char c;string hex;for(int i=0;i<dec.size();i++){ndec=ndec*10+(dec[i]-'0');}while(ndec){t=ndec%16;if(t<=9){c=t+'0';}else{c=t-10+'A';}hex=c+hex;ndec/=16;}return hex;
}

5.输出结果

//五、输出未知 if(checkHW(binary)||checkHW(hexa)){cout<<s<<endl;}

完整代码如下:

#include<bits/stdc++.h> // 包含常用头文件,简化代码,但非标准,建议具体指定所需头文件
using namespace std; // 使用std命名空间,允许直接使用std内的函数和对象,但可能引起命名冲突// 检查字符串是否为回文
bool checkHW(string t){string re = t; // 复制字符串treverse(re.begin(), re.end()); // 反转字符串return t == re; // 比较原字符串与反转后的字符串是否相等
}// 十进制字符串转二进制字符串
string decbin(string dec){int ndec = 0; // 初始化十进制数值for(int i=0; i<dec.size(); i++){ // 遍历输入字符串ndec = ndec * 10 + (dec[i] - '0'); // 将字符数字转换为整数并累加}string bin; // 初始化二进制字符串while(ndec){ // 当十进制数不为0时bin = (ndec % 2 ? '1' : '0') + bin; // 将余数添加到二进制字符串前部ndec /= 2; // 整除2进行下一轮}return bin; // 返回二进制字符串
}// 十进制字符串转十六进制字符串
string dechex(string dec){int ndec = 0; // 初始化十进制数值for(int i=0; i<dec.size(); i++){ // 遍历输入字符串ndec = ndec * 10 + (dec[i] - '0'); // 将字符数字转换为整数并累加}string hex; // 初始化十六进制字符串const char* digits = "0123456789ABCDEF"; // 十六进制字符表while(ndec){ // 当十进制数不为0时hex = digits[ndec % 16] + hex; // 添加对应的十六进制字符到字符串前部ndec /= 16; // 整除16进行下一轮}return hex; // 返回十六进制字符串
}int main(){// 主函数开始int n; // 定义整数n存储输入的整数数量cin >> n; // 读取整数nfor(int i=0; i<n; i++){ // 循环处理n个整数string s; // 存储当前输入的整数字符串cin >> s; // 读取一个整数// 如果该整数本身就是回文,则跳过if(checkHW(s)) continue;// 转换并检查二进制和十六进制形式string binary = decbin(s); string hexa = dechex(s);// 如果二进制或十六进制形式是回文,则输出原整数if(checkHW(binary) || checkHW(hexa)){cout << s << endl; // 输出整数}}// 主函数结束return 0; // 程序正常退出
}

问题:1405 - 小丽找潜在的素数?

类型:进制转换


题目描述:

小丽同学在编程中学到了二进制数的概念,她发现,有些二进制数,如果转为 10 进制,就是素数,小丽把这些数称为潜在的素数;比如 2 进制 1101011,转为 10 进制后为 107 ,就是素数。

请编程帮小丽找出,哪些二进制数转为 10 进制后,是素数,计算出这样的数有多少个?

输入:

第一行是一个整数 (10≤n≤100)。

接下来 n 行,每行是一个 30 位以内的 2 进制数

输出:

一个整数代表所有转为 10 进制后是素数的 2 进制数的个数。

样例:

输入:

6
1010000
1011
1101001
10111
111
1101011

输出:

4

在这里插入图片描述


1.分析问题

  1. 已知:n个 30 位以内的 2 进制数;

  2. 未知:输出所有转为 10 进制后是素数的 2 进制数的个数。

  3. 关系:进制转换。

2.定义变量

	//二、定义变量(已知、未知、关系)int n,c=0,t;string s; 

3.输入数据

  • 首先读取一个整数n,表示有n个二进制数需要处理。
  • 接下来进行n次循环,每次循环读取一个二进制字符串s。
	//三、输入已知cin>>n;for(int i=0;i<n;i++){cin>>s;}

4.数据计算

  • 将二进制字符串b转换为十进制整数。它从字符串的末尾开始遍历,累积每一位的值(通过减去字符’0’得到数字)并乘以当前的基数(初始为1,每次循环乘以2)。
int bindec(string b){int dec=0,q=1;for(int i=b.size()-1;i>=0;i--){dec+=(b[i]-'0')*q;q*=2;}return dec;}
  • 判断一个整数p是否为素数。
bool isPrime(int p){if(p<=3) return p>1;for(int i=2;i*i<=p;i++){if(p%i==0) return false;}return true;
}
  • 调用bindec将其转换为十进制数t,再用isPrime判断t是否为素数。如果是,则计数器c加1。
	//四、根据关系计算t=bindec(s);if(isPrime(t)) ++c;

5.输出结果

  • 循环结束后,输出计数器c的值,即转换后是素数的二进制数的个数。
	//五、输出未知 cout<<c;

完整代码如下:

#include<bits/stdc++.h> // 包含所有常用头文件
using namespace std;    // 使用std命名空间,简化代码中标准库的使用// 函数:将二进制字符串转换为十进制整数
int bindec(string b){int dec = 0, q = 1; // 初始化十进制数为0,权重为1(2的0次幂)for(int i = b.size() - 1; i >= 0; i--){ // 从字符串末尾开始遍历dec += (b[i] - '0') * q;           // 将当前位的二进制值加到十进制数上q *= 2;                             // 权重翻倍,对应二进制位的移动}return dec; // 返回转换后的十进制数
}// 函数:判断一个整数是否为素数
bool isPrime(int p){if(p <= 3) return p > 1; // 处理p为1, 2, 3的情况,其中2和3是素数for(int i = 2; i * i <= p; i++){ if(p % i == 0 ) return false; }return true; // 所有可能的因子都检查过了,p是素数
}int main(){// 主函数开始int n, count = 0; // n表示二进制数的个数,count用于统计素数的个数string binary;    // 用于存储输入的二进制字符串// 输入二进制数的个数ncin >> n;// 循环读取n个二进制数,并检查它们转换为十进制后是否为素数for(int i = 0; i < n; i++){cin >> binary; // 输入一个二进制数int decimal = bindec(binary); // 转换为十进制if(isPrime(decimal)) ++count; // 如果是素数,计数器加1}// 输出统计结果cout << count << endl; // 输出转换后为素数的二进制数的数量return 0; // 程序结束
}

三、感谢

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

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

在这里插入图片描述

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

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

相关文章

ubuntu下aarch64-linux-gnu(交叉编译) gdb/gdbserver

ubuntu下aarch64-linux-gnu(交叉编译) gdb/gdbserver gdb是一款开源的、强大的、跨平台的程序调试工具。主要用于在程序运行时对程序进行控制和检查&#xff0c;如设置断点、单步执行、查看变量值、修改内存数据等&#xff0c;从而帮助开发者定位和修复代码中的错误。 gdbserve…

密态计算,大模型商用数据瓶颈的新解法?

大数据产业创新服务媒体 ——聚焦数据 改变商业 大模型迈向产业的深度应用&#xff0c;首要挑战是高质量数据供给和安全流通。正如在今年的世界人工智能大会上&#xff0c;产学研届多位专家达成的共识是&#xff0c;数据决定了AI能力的上限。 在实践中&#xff0c;行业大模型难…

C#创建windows服务程序

步骤 1: 创建Windows服务项目 打开Visual Studio。选择“创建新项目”。在项目类型中搜索“Windows Service”并选择一个C#模板&#xff08;如“Windows Service (.NET Framework)”&#xff09;&#xff0c;点击下一步。输入项目名称、位置和其他选项&#xff0c;然后点击“创…

Pyecharts绘制热力图的说明+代码实战

引言 热力图在数据可视化中是一种强大的工具&#xff0c;可以直观地展示数据的分布情况和变化趋势。Pyecharts是一个基于Echarts的Python可视化库&#xff0c;提供了丰富的图表类型&#xff0c;包括热力图。在本文中&#xff0c;我们将深入探讨Pyecharts绘制多种炫酷热力图的参…

Qt 创建的窗口一闪而过【已解决】

Qt 创建的窗口一闪而过 引言一、详细的解决方案 - 附代码二、参考博文 引言 创建的窗口一闪而过&#xff0c;就是创建完立马被销毁了&#xff0c;常见情况是在一个函数中创建窗口并show() - 即创建在了栈上&#xff0c;函数结束局部变量(窗口)自动被释放。主流的解决方法有两种…

每日刷题(二分查找,匈牙利算法,逆序对)

目录 1.Sarumans Army 2.Catch That Cow 3.Drying 4.P3386 【模板】二分图最大匹配 5. Swap Dilemma 1.Sarumans Army 3069 -- Sarumans Army (poj.org) 这道题就是要求我们在给的的位置放入 palantir&#xff0c;每个 palantir有R大小的射程范围&#xff0c;要求求出最少…

生产订单执行明细表二开增加字段

文章目录 生产订单执行明细表二开增加字段业务背景业务需求方案设计详细设计和实现标准报表引入到应用标准报表和过滤扩展添加字段创建插件&#xff0c;挂载插件新建类库 Krystal.K3.SCGL.App.Report&#xff0c;添加引用创建类&#xff0c;继承报表原插件重写BuilderReportSql…

【微服务】Spring Cloud中如何使用Eureka

文章目录 强烈推荐引言主要功能Eureka 的架构使用示例Eureka Server 配置Eureka Client 配置示例服务服务发现调用示例 Spring Cloud如何实现服务的注册?1. 搭建 Eureka 服务注册中心2. 配置服务注册到 Eureka3. 验证服务注册 总结应用场景1. 动态服务发现2. 负载均衡3. 服务治…

基于Java中的SSM框架实现水稻朔源信息系统项目【项目源码】

基于Java中的SSM框架实现水稻朔源信息系统演示 SSM框架 SSM框架是基于Spring、SpringMVC以及Mybatis实现的针对JAVA WEB端应用的开发框架&#xff0c;通过SSM框架结构可以实现以上三种框架的优点集合&#xff0c;从而实现更加高效便捷的系统开发和呈现。该框架结构通过Spring框…

PolarisMesh源码系列——服务如何注册

前话 PolarisMesh&#xff08;北极星&#xff09;是腾讯开源的服务治理平台&#xff0c;致力于解决分布式和微服务架构中的服务管理、流量管理、配置管理、故障容错和可观测性问题&#xff0c;针对不同的技术栈和环境提供服务治理的标准方案和最佳实践。 PolarisMesh 官网&am…

280个地级市金融集聚水平数据(2006-2022年)

2006年-2022年280个地级市金融集聚水平数据整理资源-CSDN文库 金融集聚水平&#xff1a;衡量地级市金融发展的新维度 金融集聚水平是衡量一个地区金融发展程度的重要指标&#xff0c;它反映了金融机构、金融资源、金融服务在特定时间和空间的集中程度。这一指标的评估可以从多…

视语坤川大模型智能体平台亮相2024世界人工智能大会

7月4日-7月7日&#xff0c;以“以共商促共享以善治促善智”为主题的2024世界人工智能大会&#xff08;WAIC 2024&#xff09;在上海举办&#xff0c;世界顶级专家学者、知名企业代表、政界人士、高校组织等齐聚上海&#xff0c;共商发展、共话未来。 作为大会的重磅环节——昇…

【笔记】Android V 应用SDK升级适配和问题

说明 随着Google释放的Android版本,系统升级SDK到35,应用也需要升级上去,不然会报错。 Android Studio Jellyfish | 2023.3.1 | Android Developers Android Studio 预览版中的新功能 | Android Developers 当前版本的Android Studio

Elasticsearch:深度学习与机器学习:了解差异

作者&#xff1a;来自 Elastic Elastic Platform Team 近年来&#xff0c;两项突破性技术一直站在创新的最前沿 —— 机器学习 (machine learning - ML) 和深度学习 (deep learning - DL)。人工智能 (AI) 的这些子集远不止是流行语。它们是推动医疗保健、金融等各行业进步的关键…

Java面试八股之MySQL索引B+树、全文索引、哈希索引

MySQL索引B树、全文索引、哈希索引 注意&#xff1a;B树中B不是代表二叉树&#xff08;binary&#xff09;&#xff0c;而是代表平衡&#xff08;balance&#xff09;&#xff0c;因为B树是从最早的平衡二叉树演化而来&#xff0c;但是B树不是一个二叉树。 B树的高度一般在2~…

es是如何处理索引数据的变动的?

1 概述 es是如何处理索引数据的变动的&#xff1f; 或者说索引数据变动时&#xff0c;es会执行哪些操作&#xff1f; refresh、fsync、merge 和 flush 操作有何作用&#xff1f; es是如何确保即使es发生宕机数据也不丢失的&#xff1f; 在回答上述问题前&#xff0c;可以先…

文件操作和IO流

前言&#x1f440;~ 上一章我们介绍了多线程进阶的相关内容&#xff0c;今天来介绍使用java代码对文件的一些操作 文件&#xff08;file&#xff09; 文件路径&#xff08;Path&#xff09; 文件类型 文件操作 文件系统操作&#xff08;File类&#xff09; 文件内容的读…

leetcode--恢复二叉搜索树

leetcode地址&#xff1a;恢复二叉搜索树 给你二叉搜索树的根节点 root &#xff0c;该树中的 恰好 两个节点的值被错误地交换。请在不改变其结构的情况下&#xff0c;恢复这棵树 。 示例 1&#xff1a; 输入&#xff1a;root [1,3,null,null,2] 输出&#xff1a;[3,1,null…

AirPods Pro新功能前瞻:iOS 18的五大创新亮点

随着科技的不断进步&#xff0c;苹果公司一直在探索如何通过创新提升用户体验。iOS 18的推出&#xff0c;不仅仅是iPhone的一次系统更新&#xff0c;更是苹果生态链中重要一环——AirPods Pro的一次重大升级。 据悉&#xff0c;iOS 18将为AirPods Pro带来五项新功能&#xff0…

设计模式探索:观察者模式

1. 观察者模式 1.1 什么是观察者模式 观察者模式用于建立一种对象与对象之间的依赖关系&#xff0c;当一个对象发生改变时将自动通知其他对象&#xff0c;其他对象会相应地作出反应。 在观察者模式中有如下角色&#xff1a; Subject&#xff08;抽象主题/被观察者&#xf…