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

news2024/11/20 13:39:58

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;
}
心得体会:

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

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

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

相关文章

多数问题求解之蒙特卡洛与分治法

多数问题&#xff08;Majority Problem&#xff09;是一个有多种求解方法的经典问题&#xff0c;其问题定义如下&#xff1a; 给定一个大小为 n n n的数组&#xff0c;找出其中出现次数超过 n / 2 n/2 n/2的元素 例如&#xff1a;当输入数组为 [ 5 , 3 , 5 , 2 , 3 , 5 , 5 ] […

JavaEE:网络编程

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

深度学习进阶:揭秘强化学习原理,实战应用全解析!

作为机器学习领域的一大分支&#xff0c;强化学习以其独特的学习方式吸引了众多研究者和实践者的目光。强化学习&#xff0c;顾名思义&#xff0c;是通过不断地强化与环境的交互来优化决策策略。在这个过程中&#xff0c;智能体通过试错&#xff0c;根据环境给出的奖励信号来调…

Linux:导出环境变量命令export

相关阅读 Linuxhttps://blog.csdn.net/weixin_45791458/category_12234591.html?spm1001.2014.3001.5482 Linux中的内建命令export命令用于创建一个环境变量&#xff0c;或将一个普通变量导出为环境变量&#xff0c;并且在这个过程中&#xff0c;可以给该环境变量赋值。 下面…

产品测试方案:视频接入平台并发性能测试方案和报告(即150路视频并发流媒体服务器模块的性能测试方案和报告)

目 录 一、测试目的&#xff1a; 二、测试方案&#xff1a; 2.1、测试思路 2.2、拓扑图 三、测试环境 3.1 服务器配置 3.2 网络摄像机列表 3.3 测试软件 四、测试流程 4.1 H.264并发测试&#xff1a; 4.1.1老版本srsout3.10并发测试 4.1.2 新版本srsout…

反无人机电子护栏:原理、算法及简单实现

随着无人机技术的快速发展&#xff0c;其在航拍、农业、物流等领域的应用日益广泛。然而&#xff0c;无人机的不规范使用也带来了安全隐患&#xff0c;如侵犯隐私、干扰航空秩序等。为了有效管理无人机&#xff0c;反无人机电子护栏技术应运而生。 目录 一、反无人机电子护栏…

代码随想录算法训练营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生…

Grapher教程—重建长江中下游降雨量时间变化序列

各位朋友好&#xff01;非常激动&#xff01;新学了一个科研绘图软件&#xff0c;它的大名叫“Grapher”&#xff0c;也许在科研界早已如雷贯耳&#xff0c;但在我这&#xff0c;还得是第一次遇见你&#xff01;来看看小编在老师的指导下鼓捣了三节课搞出来的图。 就问大家&…

6.Java并发编程—深入剖析Java Executors:探索创建线程的5种神奇方式

Executors快速创建线程池的方法 Java通过Executors 工厂提供了5种创建线程池的方法&#xff0c;具体方法如下 方法名描述newSingleThreadExecutor()创建一个单线程的线程池&#xff0c;该线程池中只有一个工作线程。所有任务按照提交的顺序依次执行&#xff0c;保证任务的顺序性…

Mybatis-Plus实现常规增删改操作

文章目录 3.1 MP实现插入操作3.1.1 BaseMapper定义操作方法3.1.2 代码测试 3.2 MP主键字段注解-TableId3.2.1 注解TableId介绍3.2.2 MP主键生成策略介绍3.2.3 MP常用主键生成策略3.2.4 雪花算法(了解) 3.3 普通列注解-TableField3.3.1 注解TableField作用3.3.2 代码示例 3.4.MP…

自适应差分进化算法(SaDE)和差分进化算法(DE)优化BP神经网络

自适应差分进化算法(SaDE)和差分进化算法(DE)优化BP神经网络 自适应差分进化算法(SaDE)和差分进化算法(DE)可以用于优化神经网络中的参数&#xff0c;包括神经网络的权重和偏置。在优化BP神经网络中&#xff0c;DE和SaDE可以帮助找到更好的权重和偏置的组合&#xff0c;以提高…

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的交通标志识别系统详解(深度学习模型+UI界面代码+训练数据集)

摘要&#xff1a;本篇博客详细介绍了利用深度学习构建交通标志识别系统的过程&#xff0c;并提供了完整的实现代码。该系统采用了先进的YOLOv8算法&#xff0c;并与YOLOv7、YOLOv6、YOLOv5等早期版本进行了性能评估对比&#xff0c;分析了性能指标如mAP、F1 Score等。文章深入探…

4、设计模式之建造者模式(Builder)

一、什么是建造者模式 建造者模式是一种创建型设计模式&#xff0c;也叫生成器模式。 定义&#xff1a;封装一个复杂对象构造过程&#xff0c;并允许按步骤构造。 解释&#xff1a;就是将复杂对象的创建过程拆分成多个简单对象的创建过程&#xff0c;并将这些简单对象组合起来…

吴恩达机器学习-可选实验室:逻辑回归,决策边界(Logistic Regression,Decision Boundary))

文章目录 目标数据集图数据逻辑回归模型复习逻辑回归和决策边界绘图决策边界恭喜 目标 在本实验中&#xff0c;你将:绘制逻辑回归模型的决策边界。这会让你更好地理解模型的预测。 import numpy as np %matplotlib widget import matplotlib.pyplot as plt from lab_utils_co…

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

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

【网络工程师进阶之路】BFD技术

个人名片&#xff1a;&#x1faaa; &#x1f43c;作者简介&#xff1a;一名大三在校生&#xff0c;喜欢AI编程&#x1f38b; &#x1f43b;‍❄️个人主页&#x1f947;&#xff1a;落798. &#x1f43c;个人WeChat&#xff1a;hmmwx53 &#x1f54a;️系列专栏&#xff1a;&a…

第十四届蓝桥杯蜗牛

蜗牛 线性dp 目录 蜗牛 线性dp 先求到达竹竿底部的状态转移方程 求蜗牛到达第i根竹竿的传送门入口的最短时间​编辑 题目链接&#xff1a;蓝桥杯2023年第十四届省赛真题-蜗牛 - C语言网 关键在于建立数组将竹竿上的每个状态量表示出来&#xff0c;并分析出状态转移方程 in…

《详解:鸿蒙NEXT开发核心技术》

我们现在都知道鸿蒙作为一个国产的全栈自研系统&#xff0c;经过国家主推后。已经引起人们很大的关注&#xff0c;其中作为开发者来说&#xff1b;许多一线大厂已经与其华为鸿蒙展开原生应用的合作了&#xff0c;目前了解到已经有200家。而之后出现了很多的高薪鸿蒙开发岗位&am…

Unity制作马赛克效果

大家好&#xff0c;我是阿赵。   之前在玩怒之铁拳4里面&#xff0c;看到了马赛克场景转换的效果&#xff0c;觉得很有趣&#xff0c;于是也来做一下。 一、2D版本的马赛克转场效果 先看看视频效果&#xff1a; 马赛克转场 这里我是直接写shader实现的&#xff0c;我这里是把…