王道机试C++第6章 数学问题和22年蓝桥杯省赛选择题Day34

6.1 进制转换

二进制数(十转二)

习题描述

大家都知道,数据在计算机里中存储是以二进制的形式存储的。 有一天,小明学了C语言之后,他想知道一个类型为unsigned int 类型的数字,存储在计算机中的二进制串是什么样子的。 你能帮帮小明吗?并且,小明不想要二进制串中前面的没有意义的0串,即要去掉前导0。

输入描述:多行,每一行表示要求的数字

输出描述:输出共T行。每行输出求得的二进制串

代码表示:
#include <bits/stdc++.h>  
using namespace std;  
  
int main() {  
    unsigned int n;  
    while (scanf("%u", &n) != EOF) {  
        vector<int>binary; // 使用vector<bool>来存储二进制位  
        while (n != 0) {  
            binary.push_back(n % 2);  
            n /= 2; //取走余数之后剩下的 
        }  
        for (int i = binary.size()-1; i>=0; --i)//逆着读出 
		{  
            printf("%d", binary[i]);  
        }  
        printf("\n");  
    }  
    return 0;  
}

进制转换(限制范围)

题目描述:
将一个长度最多为 30 位数字的十进制非负整数转换为二进制数。
输入: 多组数据,每行为一个长度不超过 30 位的十进制非负整数。(注意是十进制数字的个数可能有 30 个,而不是 30bits 的整数)
输出: 每行输出对应的二进制数。
样例输入:
0
1
3
8
样例输出:
0
1
11
1000
思路提示:1、有人 会觉得这道题和前一道题是一样的,即都是将十进制数转换成二进制数。但本题明确指出输入的数可能多达 30 位,因此无法再用整型数来保存该题的输入,而要用字符串来模拟数字。
2、对于整除运算,需要重新写一个函数来完成字符串的除法功能。把字符串从高到低逐位除以除数。如果某位不能整除,那么就保留它除以除数的余数,余数乘以 10 后和低一位一起进行处理。这样,就能模拟出除法的效果,但这种做法可能会前置多余的 0,这时只需取首个非 0 位之后的字符串,便可得到想要的结果。
代码表示:
#include <bits/stdc++.h>
using namespace std;

string Divide(string str, int x) { // 自定义字符串除法函数
    int remainder = 0; // 保存余数
    for (int i = 0; i < str.size(); ++i) {
        int current = remainder * 10 + str[i] - '0';
        str[i] = current / x + '0'; // 更新商的字符表示
        remainder = current % x; // 更新余数
    }
    int pos = 0;
    while (str[pos] == '0') { // 寻找首个非 0 下标
        pos++;
    }
    return str.substr(pos); // 删除前置多余的 0
}

int main() {
    string str;
    while (cin >> str) {
        vector<int> binary; // 存储二进制位
        while (str.size() != 0) {
            int last = str[str.size() - 1] - '0'; // 获取最低位的值
            binary.push_back(last % 2); // 将最低位对2取模,得到二进制位
            str = Divide(str, 2); // 将当前数值整除以2
        }
        for (int i = binary.size() - 1; i >= 0; --i) { // 逆序输出二进制位
            printf("%d", binary[i]);
        }
        printf("\n");
    }
    return 0;
}

6.2 最大公约数与最小公倍数

最大公约数(哈工大)

题目描述:
输入两个正整数,求其最大公约数。
输入: 测试数据有多组,每组输入两个正整数。
输出: 对于每组输入,请输出其最大公约数。
样例输入:
49 14
样例输出:
7
代码表示:
#include <bits/stdc++.h>
using namespace std;

int GCD(int a, int b) {
    if (b == 0) {
      return a;
    } else {
        return GCD(b, a % b);
    }
}
int main() {
        int a, b;
        while (scanf("%d%d", &a, &b) != EOF) {
           printf("%d\n", GCD(a, b));
		   }
    return 0;
}
心得体会:

举例说明这个GCD(a,b)是什么意思

假设我们要计算 48 和 18 的最大公约数(GCD)。

  1. 因为 b(18)不等于 0,所以我们继续调用 GCD(18, 48 % 18)。
  2. 计算 48 除以 18 的余数,得到 12。现在我们将调用 GCD(18, 12)。
  3. 因为 b(12)不等于 0,所以我们再次调用 GCD(12, 18 % 12)。
  4. 计算 18 除以 12 的余数,得到 6。现在我们将调用 GCD(12, 6)。
  5. 因为 b(6)不等于 0,所以我们再次调用 GCD(6, 12 % 6)。
  6. 计算 12 除以 6 的余数,得到 0。现在我们将调用 GCD(6, 0)。
  7. 因为此时 b(0)等于 0,根据代码中的逻辑,返回 a(6)作为最大公约数。

因此,最终得到 48 和 18 的最大公约数是 6。


最小公倍数

题目描述:
给定两个正整数,计算这两个数的最小公倍数。
输入:
输入包含多组测试数据,每组只有一行,包括两个不大于 1000 的正整数。
输出:
对于每个测试用例,给出这两个数的最小公倍数,每个实例输出一行。
样例输入:
10 14
样例输出:
70
代码表示:
#include <bits/stdc++.h>
using namespace std;

int GCD(int a, int b) {
    if (b == 0) {
        return a;
    } else {
        return GCD(b, a % b);
    }
}
int main() {
    int a, b;
    // 循环读取输入的两个整数,并计算它们的最大公约数
    while (scanf("%d%d", &a, &b) != EOF) {
        // 输出 a 和 b 的乘积除以它们的最大公约数
        printf("%d\n", a * b / GCD(a, b));
    }
    return 0;
}

心得体会:我滴天!这就是最小公倍数  a * b / GCD(a, b)


6.3 质数

质数也称素数,是指只能被其自身和 1 整除的正整数。

素数判定(哈工大复试)

题目描述:
给定一个数 n ,要求判断其是否为素数( 0, 1 和负数都是非素数)。
输入: 测试数据有多组,每组输入一个数 n
输出: 对于每组输入,若是素数则输出 yes ,否则输出 no
样例输入:
13
样例输出:

yes

代码表示:
#include <bits/stdc++.h>
using namespace std;

bool Judge(int x) { // 判断是否为质数
    if (x < 2) { // 小于 2 必定不是质数
        return false;
    }
    int bound = sqrt(x); // 确定判断上界
    for (int i = 2; i <= bound; ++i) {
        if (x % i == 0) {
            return false; // 如果能被整除,不是质数
        }
    }
    return true; // 是质数
}
int main() {
    int n;
    while (scanf("%d", &n) != EOF) {
        if (Judge(n)) {
            printf("yes\n"); // 是质数输出 yes
        } else {
            printf("no\n"); // 不是质数输出 no
        }
    }
    return 0;
}
心得体会:

注意的点应该放在 int bound = sqrt(x); 确定判断上界!!!仔细想一下确实,还有小于2必定不是,所以在单独的函数开始的时候就可以把他放在最后。


素数(北航上机题)

题目描述:
输入一个整数 n 2 <=   n <= 10000 ),要求输出所有从 1 到这个整数之间(不包括 1 和这个整数)个位为 1 的素数,若没有则输出- 1
输入:输入有多组数据。 每组一行,输入 n
输出: 输出所有从 1 到这个整数之间(不包括 1 和这个整数)个位为 1 的素数(素数之间用空格隔开, 最后一个素数后面没有空格),若没有则输出-1
样例输入:
100
样例输出:
11 31 41 61 71
代码表示:
#include <bits/stdc++.h>
using namespace std;

const int MAXN = 10001;
vector<int> prime; // 保存质数
bool isPrime[MAXN]; // 标记数组
void Initial() {
	//初始化质数 
    for (int i = 0; i < MAXN; ++i)
	{ // 初始化
        isPrime[i] = true;
    }
    //将 0 和 1 标记为非质数。
    isPrime[0] = false;
    isPrime[1] = false;
    //再次循环遍历从 2 到 MAXN-1 的所有数字。
    for (int i = 2; i < MAXN; ++i) {
        if (!isPrime[i]) { // 非质数则跳过
            continue;
        }
        prime.push_back(i);//当前质数 i 加入到 prime 容器中
        for (int j = i * i; j < MAXN; j += i) {
            isPrime[j] = false; // 质数的倍数为非质数
        }
    }
}
int main() {
    Initial();
    int n;
    while (scanf("%d", &n) != EOF) {
        bool isOutput = false; // 判断是否有输出
        for (int i = 0; i < prime.size() && prime[i] < n; ++i) {
            if (prime[i] % 10 == 1) { // 判断个位是否为 1
                isOutput = true;
                printf("%d ", prime[i]);
            }
        }
        if (!isOutput) {
            printf("-1");
        }
        printf("\n");
    }
    return 0;
}
心得体会:

1、if (prime[i] % 10 == 1) 是用来判断当前循环到的质数 prime[i] 的个位数字是否为 1。具体来说,当一个质数除以 10 取模的结果等于 1 时,就满足这个条件。

例如,假设当前循环到的质数是 31。那么,31 % 10 的结果是 1,因此它符合条件。而当质数是 37 时,37 % 10 的结果是 7,不等于 1,因此不符合条件。

2、isPrime 的作用是在初始化时标记每个数字是否为质数,以便后续的操作中能够快速判断一个数是否为质数。通过标记数组,可以在程序运行过程中避免重复计算某个数是否为质数,提高程序的效率。

具体来说:

1)在初始化时,通过标记数组将所有数字标记为质数或非质数。

2)在找出质数并存储到 prime 容器中时,利用标记数组跳过已经标记为非质数的数字,减少不必要的计算。

3)在输出符合条件的质数时,也可以利用标记数组快速判断一个数是否为质数。


[蓝桥杯 2023 省 B] 接龙数列

题目描述

对于一个长度为 K 的整数数列:1,2,…,A1​,A2​,…,AK​,我们称之为接龙数列当且仅当 Ai​ 的首位数字恰好等于 Ai−1​ 的末位数字(2≤i≤K)。

例如 12,23,35,56,61,11 是接龙数列;12,23,34,56 不是接龙数列,因为 56 的首位数字不等于于 34 的末位数字。所有长度为 1 的整数数列都是接龙数列。

现在给定一个长度为 N 的数列A1​,A2​,…,AN​,请你计算最少从中删除多少个数,可以使剩下的序列是接龙序列?

输入格式

第一行包含一个整数 N。

第二行包含 N 个整数A1​,A2​,…,AN​。

输出格式

一个整数代表答案。

代码表示:
#include<bits/stdc++.h>
using namespace std;
int n,m,i,dp[10];
string a;//用字符串存储,便于运算
int main(){
  ios::sync_with_stdio(false);
  cin>>n;
  for(i=n;i--;){
  cin>>a;
  dp[a[a.size()-1]-48]=max(dp[a[a.size()-1]-48],dp[a[0]-48]+1);//如果a有贡献
}
  for(i=0;i<=9;i++)m=max(m,dp[i]);//取最大值
  cout<<n-m;
}
心得体会:

明天学完动态规划再来看(((φ(◎ロ◎;)φ)))(((φ(◎ロ◎;)φ)))

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

个人博客系统(测试报告)

一、项目背景 一个Web网站程序&#xff0c;你可以观看到其他用户博客也可以登录自己的账号发布博客&#xff0c;通过使用Selenium定位web元素、操作测试对象等方法来对个人博客系统的进行测试&#xff0c;测试的核心内容有用户登录、博客列表及博客数量的展示、查看全文、写博客…

Vue-Vben-Admin:中大型项目后台解决方案及如何实现页面反向传值

Vue-Vben-Admin&#xff1a;中大型项目后台解决方案及如何实现页面反向传值 摘要&#xff1a; Vue-Vben-Admin是一个基于Vue3.0、Vite、Ant-Design-Vue和TypeScript的开源项目&#xff0c;旨在为开发中大型项目提供一站式的解决方案。它涵盖了组件封装、实用工具、钩子函数、动…

Python逆向:pyc字节码转py文件

一、 工具准备 反编译工具&#xff1a;pycdc.exe 十六进制编辑器&#xff1a;010editor 二、字节码文件转换 在CTF中&#xff0c;有时候会得到一串十六进制文件&#xff0c;通过010editor使用查看后&#xff0c;怀疑可能是python的字节码文件。 三、逆向反编译 将010editor得到…

链路聚合实验(思科)

华为设备参考&#xff1a; 一&#xff0c;技术简介 网络设备的链路聚合技术&#xff08;Link Aggregation&#xff09;是一种将多个物理链路捆绑在一起&#xff0c;形成一个逻辑链路的技术。这样做可以增加带宽、提高可靠性和实现负载均衡。 二&#xff0c;实验目的 橙色的阻…

使用Sourcetree推送本地仓库至远程仓库时报错The host key is not cached for this server

原因是SSH没配置好 点击工具→选项→ 改成OpenSSH&#xff0c;密钥改成配置Git和本地仓库时生成的.ssh文件夹下的id_rsa文件。

Spring boot 集成netty实现websocket通信

一、netty介绍 Netty 是一个基于NIO的客户、服务器端的编程框架&#xff0c;使用Netty 可以确保你快速和简单的开发出一个网络应用&#xff0c;例如实现了某种协议的客户、服务端应用。Netty相当于简化和流线化了网络应用的编程开发过程&#xff0c;例如&#xff1a;基于TCP和U…

力扣-[700. 二叉搜索树中的搜索]

递归法 确定递归函数的参数和返回值 递归函数的参数传入的就是根节点和要搜索的数值&#xff0c;返回的就是以这个搜索数值所在的节点。 代码如下&#xff1a; public TreeNode searchBST(TreeNode root, int val) 确定终止条件 如果root为空&#xff0c;返回null&#xff0c…

【前端】HTML常用标签

因为想当个全栈&#xff0c;所以巩固了一下HTML与CSS和JS基础&#xff0c;这一篇博客是HTML部分 文章目录 HTML 基础标签 1HTML 基础框架HTML 基础标签语义标签文本格式化标签div 与 span 标签图像标签超链接特殊字符 基础标签 2 | 表格表格的使用表格标签表格属性表格的头部与…

JavaEE:网络编程

网络编程&#xff1a;通过代码完成基于网络的跨主机通信 跨主机通信方式&#xff1a; 1.TCP/IP网络 2.蓝牙通信 3.近场通信NFC 4.毫米波通信&#xff1a;功率高&#xff0c;带宽高&#xff0c;抗干扰能力差 其中TCP/IP网络是日常编程中最常涉及到的&#xff0c;最通用的跨主机通…

蓝桥杯 2022 dp 背包

蓝桥杯 2022 dp 背包 题目链接&#xff1a; https://www.lanqiao.cn/problems/2186/learning/?subject_code1&group_code4&match_num13&match_flow2&origincup 题目&#xff1a; 代码&#xff1a; #include<bits/stdc.h> using namespace std;#defi…

代码随想录算法训练营第七天| 454.四数相加II、383.赎金信、15.三数之和、18.四数之和

系列文章目录 目录 系列文章目录454.四数相加II使用HashMap法 383.赎金信哈希解法&#xff08;数组&#xff09; 15.三数之和双指针法 18.四数之和双指针法 454.四数相加II 题解&#xff1a;该题和1.两数之和的方法是一样的&#xff0c;这个题的难点在于key和value分别是什么。…

网络建设与运维培训介绍和能力介绍

1.开过的发票 3.培训获奖的证书 4合同签署 5.实训设备

垃圾回收器介绍

java堆内存结构包括&#xff1a;新生代和老年代&#xff0c;其中新生代由一个伊甸区和2个幸存区组成&#xff0c;2个幸存区是大小相同&#xff0c;完全对称的&#xff0c;没有任何差别。我们把它们称为S0区和S1区&#xff0c;也可以称为from区和to区。 JVM的垃圾回收主要是针对…

Spring具体拓展点:后置处理器

一图胜千言 mermaid示例图&#xff1a; #mermaid-svg-YEqFb5JcEk5FWkwO {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-YEqFb5JcEk5FWkwO .error-icon{fill:#552222;}#mermaid-svg-YEqFb5JcEk5FWkwO .error-text{fi…

详细分析Mysql中的LOCATE函数(附Demo)

目录 1. 基本概念2. Demo3. 实战 1. 基本概念 LOCATE()函数在SQL中用于在字符串中查找子字符串的位置 它的一般语法如下&#xff1a; LOCATE(substring, string, start)LOCATE()函数返回子字符串在主字符串中第一次出现的位置 如果未找到子字符串&#xff0c;则返回0 具体的…

stm32学习笔记:SPI通信协议原理(未完)

一、SPI简介(serial Peripheral Interface&#xff08;串行 外设 接口&#xff09;) 1、电路模式&#xff08;采用一主多从的模式&#xff09;、同步&#xff0c;全双工 1 所有SPI设备的SCK、MOSI、MISO分别连在一起 2 主机另外引出多条SS控制线&#xff0c;分别接到各从机的S…

数据集成工具 ---- datax 3.0

1、datax: 是一个异构数据源离线同步工具&#xff0c;致力于实现关系型数据库&#xff08;mysql、oracle等&#xff09;hdfs、hive、hbase等各种异构数据源之间的数据同步 2、参考网址文献&#xff1a; https://github.com/alibaba/DataX/blob/master/introduction.mdhttps:/…

代码随想录算法训练营Day46 ||leetCode 139.单词拆分 || 322. 零钱兑换 || 279.完全平方数

139.单词拆分 class Solution { public:bool wordBreak(string s, vector<string>& wordDict) {unordered_set<string> wordSet(wordDict.begin(), wordDict.end());vector<bool> dp(s.size() 1, false);dp[0] true;for (int i 1; i < s.size(); …

【Linux】-Linux下的软件商店yum工具介绍(linux和windows互传文件仅仅一个拖拽搞定!!!!)

目录 1.Linux 软件包管理器yum 1.1快速认识yum 1.2 yumz下载方式&#xff08;如何使用yum进行下载&#xff0c;注意下载一定要是root用户或者白名单用户&#xff08;可提权&#xff09;&#xff09; 1.2.1下载小工具rzsz 1.2.2 rzsz使用 1.2.2查看软件包 1.3软件的卸载 2.yum生…

三、HarmonyOS 应用开发入门之运行Hello World

目录 1、课程对象 1.1、有移动端开发经验 1.2、无移动端开发经验 1.3、对 HarmonyOS 感兴趣 2、DevEco Studio 的使用 2.1、DevEco Studio 的关键特性 智能代码编辑 低代码开发 多段双向实时预览 多端模拟仿真 2.2、安装配置 DevEco Studio 2.2.1、官网开发工具下载地…