蓝桥杯算法训练合集十三 1.P06022.P07033.逗志芃的危机4.唯一的小可爱5.JOE的矩阵

news2024/11/27 6:39:39

目录

1.P0602

2.P0703

3.逗志芃的危机

4.唯一的傻子

5.JOE的矩阵


1.P0602

问题描述

编写一个程序,输入一个4位的自然数,将组成该数的各位数字重新排列,形成一个最大数和一个最小数,之后用最大数减去最小数,得到一个新的自然数,把这个数打印出来。然后对于这个新的自然数,重复上述步骤,直到该自然数的值不再发生变化。例如,假设用户输入的自然数为1001,那么由它所形成的最大数为1100,最小数为11,因此新的自然数为1089。对于1089,由它形成的最大数为9810,最小数为189,因此新的自然数为9621。9621的最大数为9621,最小数为1269,结果为8352,。8352的最大数为8532,最小数为2358,结果为6174。6174的最大数为7641,最小数为1467,结果仍为6174,因此程序结束。

样例输入

1001

样例输出

6174

示例代码

#include<iostream>
#include<algorithm>
using namespace std;

int main() {
	int n, a[4];
	cin >> n;
	int max, min;
	while (1) {
		int temp = 1000,n1=n;
		for (int i = 0; i < 4; i++) {//找到每个位上的数
			a[i] = n / temp;
			n -= a[i] * temp;
			temp /= 10;
		}
		sort(a, a + 4);//从小到大排序
		min = a[0] * 1000 + a[1] * 100 + a[2] * 10 + a[3] * 1;
		max = a[0] * 1 + a[1] * 10 + a[2] * 100 + a[3] * 1000;
		if (max - min == n1) {//如果符合题目要求
			cout << n1;
			return 0;
		}
		n = max - min;//否则继续循环
	}
	return 0;
}

2.P0703

问题描述

一个整数的反置数指的是把该整数的每一位数字的顺序颠倒过来所得到的另一个整数。如果一个整数的末尾是以0结尾,那么在它的反置数当中,这些0就被省略掉了。比如说,1245的反置数5421,而1200的反置数是21。请编写一个程序,输入两个整数,然后计算这两个整数的反置数之和sum,然后再把sum的反置数打印出来。例如,如果用户输入:435和754,则输出结果为199。要求:由于在本题中需要多次去计算一个整数的反置数,因此必须把这部分代码抽象为一个函数的形式。

样例输入

435 754

样例输出

199

示例代码

#include<iostream>
#include<algorithm>
using namespace std;
int find_count(int n) {//求出n是几位数
	int cnt=0;
	int temp = 1;
	for (int i = 0;; i++) {//从10的0次方开始
		if (n / temp == 0) {
			cnt = i;
			break;
		}
		temp *= 10;
	}
	return cnt;
}
int fanzhi(int n) {
	int temp = 1,temp1,cnt=0,index[12] = { 0 };
	cnt = find_count(n);
	for (int i = 1; i < cnt; i++) {//最高位的10次方值
		temp *= 10;
	}
	temp1 = temp;
	for (int i = 0; i < cnt; i++) {//分解每个位置上的数
		index[i] = n/ temp;
		n = n - index[i] * temp;
		temp /= 10;
	}
	n = 0;
	for (int i = cnt - 1; i >= 0; i--) {//倒序
		n += index[i] * temp1;
		temp1 /= 10;
	}
	//cout <<cnt<<" "<< n << endl;
	return n;
}
int main() {
	int a, b,sum;
	cin >> a >> b;
	sum = fanzhi(a) + fanzhi(b);
	sum = fanzhi(sum);
	cout << sum;
	return 0;
}

3.逗志芃的危机

问题描述

逗志芃又一次面临了危机。逗志芃的妹子是个聪明绝顶的人,相比之下逗志芃就很菜了。现在她妹子要和他玩一个游戏,这个游戏是这样的:一共有n个数(n是偶数)写成一行,然后两个人轮流取数,每次只能从最前面或者最后面取走一个数,全部取完则游戏结束,之后每个人取走的数的和就是每个人的得分。由于逗志芃妹子很厉害,但他又不想输,所以只能找到你了,你要告诉他最多可以得到多少分。(注意,妹子智商是maxlongint所以是不会犯错的,每次的策略必然最优,而且逗志芃是先手)

输入格式

第一行一个数n,表示有n个数。
第二行就是进行游戏的n个数。

输出格式

一个数,最高得分

样例输入

2
10 20

样例输出

20

数据规模和约定

例:0<n,m<=1000,每个数不超过10000 。

示例代码

#include<iostream>
using namespace std;

int max(int a, int b) {
	if (a > b) {
		return a;
	}
	else {
		return b;
	}
}
int min(int a, int b) {
	if (a > b) {
		return b;
	}
	else {
		return a;
	}
}
int a[1000], res[1000][1000];//res[l][r]表示l到r区间里逗哥所能取的最大和

int main() {
	int n,sum=0;
	cin >> n;
	for (int i = 0; i < n; i++) {
		cin >> a[i];
	}
	for (int r = 0; r < n; r++) {
		for (int l = r; l >= 0; l--) {
			if (l == r) {//妹妹选,而且是最后一个数,她没得选
				res[l][r] = 0;
			}
			else if ((r - l) % 2 == 1) {//我们选择,尽可能大
				res[l][r] = max(res[l + 1][r] + a[l], res[l][r - 1] + a[r]);
			}
			else {//妹妹选,她更大,也就是尽量让我们小
				res[l][r] = min(res[l + 1][r], res[l][r - 1]);
			}
		}
	}
	cout <<res[0][n-1];
	return 0;
}

4.唯一的傻子

问题描述

腿铮找2255有点事,但2255太丑了,所以腿铮不知道他的长相。正愁不知道到如何找他的时候,他突然看见计33班围成了一个圈在领微积分试卷。计33班有n个人,其中班长编号为0,其余同学依次按顺时针方向编号。
只听见计33小导说“x号同学顺时针方向往后数的第k个的神犇出列(不包括x号同学),领取满分试卷!”。剩下的人继续围成一个小圈。这样一个过程持续了n-1次,那么显然,最后只剩下了一个人。众所周知,2255是个大傻子,门门挂科,不符合满分试卷这一前提条件。通过这样一个过程,腿铮终于找到了2255并血虐了他。
求2255的编号是多少。

输入格式

第一行一个n,表示计33班的人数。
接下来n-1行,表示小导说话中的x和k。

输出格式

一个数字,表示2255的编号。

样例输入

3
1 1
0 1

样例输出

0

数据规模和约定

前90%数据保证n<=10^4.
前100%数据保证n<=10^6,1<=k<min(当时圈中人数,1000)

示例代码

1.链表,最后一个超时了

#include<iostream>
#include<malloc.h>
using namespace std;

typedef struct stu {
	int number;//学生编号
	struct stu *next;
}STU;

void link_creat_head(STU** p_head, STU* p_new)
{
    STU* p_mov = *p_head;
    if (*p_head == NULL)	//当第一次加入链表为空时,head执行p_new
    {
        *p_head = p_new;
        p_new->next = NULL;
    }
    else //第二次及以后加入链表
    {
        while (p_mov->next != NULL)
        {
            p_mov = p_mov->next;	//找到原有链表的最后一个节点
        }

        p_mov->next = p_new;	//将新申请的节点加入链表
        p_new->next = NULL;
    }
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    STU* head = NULL, * p_new = NULL;
    int n;
    scanf("%d", &n);
    for (int i = 0; i < n; i++) {
        p_new = (STU*)malloc(sizeof(STU));//申请一个新节点
        p_new->number = i;
        link_creat_head(&head, p_new);	//将新节点加入链表
    }
    int start, k;
    for (int i = 0; i < n - 1; i++) {
        scanf("%d %d", &start, &k);
        p_new = head;
        while (p_new->number != start) {//找到编号为start的学生
            p_new = p_new->next;
        }
        for (int j = 0; j < k-1; j++) {//找到这个学生,这个学生的下一个学生会被删除
            if (p_new->next == NULL) {//如果这个学生是链表尾部,那么该学生下一个为队首
                p_new = head;
                continue;
            }
            p_new = p_new->next;
        }
        if (p_new->next == NULL) {//如果要删除的学生为空,说明是删除的是队首,则要更新队首
            head = head->next;
        }
        else {
            p_new->next = p_new->next->next;
        }
    }
    printf("%d",head->number);
	return 0;
}

2.逻辑分析(简单法)

当输入第n-1个时,还剩两个学生,要删除的肯定不是输入的那个学生,则最后一个输入的学生就是仅存下来的学生

#include<iostream>
using namespace std;
 
int main(){
	int n;
	cin>>n;
	int x,k;
	for(int i=0;i<n-1;i++){
		scanf("%d%d", &x,&k);
	}
	cout<<x<<endl;
	return 0;
}

5.JOE的矩阵

问题描述

最近JOE又在线性代数的模拟考中拿满分了,这直接导致了JOE对于计算矩阵的热情急剧下降,所以JOE希望能有这样一个程序能帮助他计算矩阵的秩。

输入格式

第一行,两个数n,m,表示矩阵是n*m的。
下面共n行,每行m个数(可能为负),表示这个矩阵。

输出格式

这个矩阵的秩。

样例输入

2 3
1 2 1
2 4 3

样例输出

2

数据规模和约定

40% n, m <= 5
70% n, m <= 10
100% n, m <= 20

分析

用寻找非零子式的方法确定矩阵的秩有其局限性,当矩阵阶数较高时,计算量会显著增加,因此在线性代数中使用初等变换化行阶梯型,是常用的方法。

示例代码

#include <iostream>
#include <cstdio>
#include <cmath>
#include <algorithm>

using namespace std;

const int N = 110;
const double eps = 1e-8;

double a[N][N];
int n, m;

int gauss() {
    int r, c;
    for (r = 0, c = 0; c < n; c++) {//对第c列进行处理,则要将第c行包括之后的行进行处理

        // 找到最大值的行
        int t = r;
        for (int i = r; i < n; i++) {
            if (fabs(a[i][c]) > fabs(a[t][c]))
                t = i;
        }

        if (fabs(a[t][c]) < eps) continue;//如果最大的都是0,则该列以及对应的行不需要处理了

        // 2. 交换到对应的列的首行
        for (int i = c; i < m; i++) swap(a[r][i], a[t][i]);

        // 3. 本行首列置为1
        for (int i = m - 1; i >= c; i--) a[r][i] /= a[r][c];

        // 4. 下面的行首列置为0
        for (int i = r + 1; i < n; i++) {
            if (fabs(a[i][c]) < eps) continue;
            for (int j = m - 1; j >= c; j--) {
                a[i][j] -= a[i][c] * a[r][j]; // - 首航本列 * i, r首列商
            }
        }

        r++;
    }
    return r;
}

int main() {
    cin >> n >> m;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            scanf("%lf", &a[i][j]);
            // printf("%.2lf\n", a[i][j]);
        }
    }

    int t = gauss();
    printf("%d\n", t);
    return 0;
}

蓝桥杯算法训练-JOE的矩阵_天下一般的博客-CSDN博客

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

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

相关文章

数据库管理-第五十六期 监控(20230210)

数据库管理 2023-02-10第五十六期 监控1 怎么监控2 直观3 历史分析4 另一个BUG总结第五十六期 监控 春节后的7天班过后就来到了2月份&#xff0c;本周对之前发现X8M上的那个bug进行补丁修复和协助从12.2迁移了一套PDB到这个一体机上面&#xff0c;2次割接。这周还和原厂老大哥…

Android 面试三部曲——你做到了几点?

今天的干货来点轻松一点的&#xff0c;这次的分享是《面试需要哪些准备&#xff1f;》&#xff0c;主要分为三个部分&#xff1a; 面试前。面试中。面试后。 面试前 1、『工作经验中的职位要层层递进&#xff1a;初、中、高、资深级』&#x1f352; 2.投简历 你的简历必须要…

C/C++:程序环境和预处理/宏

程序的翻译环境和执行环境 在ANSI C的任何一种实现中&#xff0c;存在两个不同的环境。第1种是翻译环境&#xff0c;在这个环境中源代码被转换为可执行的机器指令。第2种是执行环境&#xff0c;它用于实际执行代码。 编译和链接 一份源代码(比如test.c)需要通过编译&#xf…

SSO单点登录 - 多系统,单一位置登录,实现多系统同时登录 学习笔记

(1)单点登录 多系统的前提下&#xff0c;单一位置的登录&#xff0c;会实现多系统同时登录的一种技术。 常出现在互联网应用和企业级平台中 如&#xff1a;京东 单点登录一般是用于互相授信的系统&#xff0c;实现单一位置登录&#xff0c;全系统有效的。 注意&#xff1a…

我看ChatGPT

ChatGPT出现后惊喜或惊醒了很多人。惊喜是因为没想到大型语言模型&#xff08;LLM,Large Language Model&#xff09;效果能好成这样&#xff1b;惊醒是顿悟到我们对LLM的认知及发展理念&#xff0c;距离世界最先进的想法&#xff0c;差得有点远。我属于后知后觉的那批人&#…

ubuntu 使用 adb 工具卸载鸿蒙系统预装软件

准备工作 打开 USB 调试 进入 “设置->关于手机” 连续点击版本号, 直到有提示开启了"开发人员选项" 进入 “设置->系统和更新->开发人员选项”, 打开 USB 调式, 顺便可以把"自动系统更新"关了 下载 adb 工具 官方地址: https://developer.an…

打通数据价值链,百分点数据科学基础平台实现数据到决策的价值转换 | 爱分析调研

随着企业数据规模的大幅增长&#xff0c;如何利用数据、充分挖掘数据价值&#xff0c;服务于企业经营管理成为当下企业数字化转型的关键。 如何挖掘数据价值&#xff1f;企业需要一步步完成数据价值链条的多个环节&#xff0c;如数据集成、数据治理、数据建模、数据分析、数据…

CoreData + CloudKit 支持的 App 在导出(export)新建托管对象时内存飙升导致被杀死的解决

问题现象 CoreData + CloudKit 支持的 App 在新建托管对象并同步导出到云时可能会导致进程内存疯狂增长,最终很快被系统杀死。 如果你的 App 满足以下三点,那么很可能出现这种情况: CoreData + CloudKit 支持云存储中已存入大量数据(1.5GB+)CoreData 数据结构包含若干一…

一起学习用Verilog在FPGA上实现CNN----(六)SoftMax层设计

1 SoftMax层设计 1.1 softmax SoftMax函数的作用是输入归一化&#xff0c;计算各种类的概率&#xff0c;即计算0-9数字的概率&#xff0c;SoftMax层的原理图如图所示&#xff0c;输入和输出均为32位宽的10个分类&#xff0c;即32x10320 本项目softmax实现逻辑为&#xff1a; …

计算机操作系统 左万利 第二章课后习题答案

计算机操作系统 左万利 第二章课后习题答案 1、为何引进多道程序设计&#xff0c;在多道程序设计中&#xff0c;内存中作业的道数是否越多越好&#xff1f;说明原因。 引入多道程序设计技术是为了提高计算机系统资源的利用率。在多道程序系统中&#xff0c;内存中作业的道数并…

Windows 搭建ARM虚拟机 UOS系统

搭建环境安装虚拟机下载虚拟机QEMU&#xff0c;https://www.qemu.org/download/&#xff0c;目前最新版本是7.2.0。安装完成后&#xff0c;需要将qemu的安装路径设置到环境变量完成后运行cmd&#xff0c;测试环境变量配置完成。qemu-system-aarch64 --version如上截图所示&…

【QT】QHostInfo 和 QNetworkInterface 的使用

目录1. Qt网络模块2. QHostInfo2.1 公共函数2.2 静态函数3. QNetworkInterface3.1 公共函数3.2 静态函数4. 代码示例Dialog.hDialog.cpp界面展示1. Qt网络模块 使用Qt网络模块&#xff0c;需要在配置文件.pro中添加&#xff1a; Qt network2. QHostInfo 2.1 公共函数 QLis…

10分钟学会Jmeter接口测试

一提到接口测试&#xff0c;通常大家会有这样的疑问&#xff1a;前端测试不是已经覆盖到各种业务逻辑了吗&#xff1f;为什么还要做接口测试&#xff0c;接口测试和前端测试是不是重复了&#xff1f;对于这个问题&#xff0c;可以从下面几个方面来解释&#xff1a; 什么是接口…

OpenMMLab AI实战营 第6课 语义分割与MMSegmentation

第6课 语义分割与MMSegmentation 1. 语义分割简介 任务&#xff1a;将图像按照物体的类别分割成不同的区域&#xff0c;等价于对每个像素进行分类应用 无人驾驶人像分割智能遥感医疗影像分析 语义分割 vs 实例分割 vs 全景分割 语义分割&#xff1a;仅考虑像素的类别&#xf…

如何利用火遍全球的ChatGPT搞钱?

火遍全球的ChatGPT想必大家都知道了。已经有人借助它赚到了2023年的第一桶金&#xff0c;连比尔盖茨都称赞ChatGPT不亚于互联网的诞生。还有人借助Chagpt通过了Google面试&#xff0c;拿到了年薪18万美元的工程师offer。要明白&#xff0c;年薪百万的谷歌程序员&#xff0c;对于…

百度富文本UE的问题集合

百度富文本编辑能上传视频成功但是在浏览器不能播放、显示的问题百度富文本视频封面空白问题百度富文本编辑器UMEditor 添加视频无法删除百度富文本编辑器结果存数据库取出来到js赋值报错怎么让浏览器重新加载修改过的JS文件&#xff0c;而不是沿用缓存里的百度富文本编辑能上传…

智慧物流管理系统

智慧物流运用物联网、大数据、云计算、人工智能等技术优化物流决策过程。智慧物流获取、分析物流信息并做出决策&#xff0c;从商品源开始实时跟踪与管理&#xff0c;保证信息流快于商品流&#xff0c;实现信息与物质快速、高效、流畅地运转&#xff0c;集自动化、数字化、网络…

浏览器如何使用HTTP防止ip限制

当我们浏览网页尤其是频发刷新网页时&#xff0c;会跳出来验证码。主要因为频繁刷新导致目标网页限制了您本地ip&#xff0c;正常过一段时间也或许恢复&#xff0c;如果遇到紧急的事情急需访问&#xff0c;不妨试试下面的操作。不管是网页还是电脑游戏都可以通过改变地址实现防…

Linux内核移植(源码分析、配置与编译)

目录 一、Linux内核概述 1.1内核与操作系统 ​编辑1.2Linux层次结构 1.3Linux内核特点 二、Linux内核源码结构 2.1Linux内核源码获取 2.2Linux内核源码结构 三、Linux内核源码的配置和编译 3.1Linux内核源码配置 3.2make menuconfig 3.3内核编译&#xff08;以下命令…

Java学习记录day6

书接上回 类与对象 static关键字 static的作用&#xff1a; 修饰一个属性&#xff1a;声明为static的变量实质上就是一个全局变量,其生命周期为从类被加载开始一直到程序结束&#xff1b;修饰方法&#xff1a;无须本类的对象也可以调用该方法&#xff1b;修饰一个类&#x…