蓝桥杯每日一题2023.9.29

蓝桥杯大赛历届真题 - C&C++ 大学 B 组 - 蓝桥云课 (lanqiao.cn)

题目描述1

题目分析

看见有32位,我们以此为入手点,

B代表字节1B = 8b

b代表位,32位即4个字节 (B)

1KB = 1024B

1MB = 1024KB

(256 * 1024 * 1024) / 4 = 67108864

故答案为67108864

题目描述2

题目分析

只需将0~9每个数组当成一类卡片,如果循环到的数字需要就可以将此减去。如果减到会小于0就输出此+1即可(答案3181)

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int f[N], flag;
int main()
{
	for(int i = 0; i <= 9; i ++)
	{
		f[i] = 2021;
	}
	for(int i = 1; ; i ++)
	{
		int x = i; 
		while(x)
		{
			int y = x % 10;
			x /= 10;
			if(f[y] > 0)f[y] --;
			else
			{
				flag = i;
				break;
			}
		}
		if(flag)break;
	}
	cout << flag - 1;
	return 0;
}

题目描述3

题目分析

注:要确定有多少条不同的直线,需要将相同的直线不算进去,我们可以进行暴力枚举,当其

x1 == x2 或者 y1 == y2是其斜率为垂直于X轴或者平行于X轴的直线这些线一共有41条,我们可以

将其放在最后相加,我们将所有的直线都枚举出来存入set中,set会自动去重,找出set中线的个数

即可。

思考:将直线存入set我们主要存的是斜率以及截距,斜率与截距确定一条直线y = kx + b

其斜率:(y2 - y1) / (x2 - x1)

我们计算截距的时候不能直接使用计算好的斜率进行计算,因为会损失精度造成错误

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 2e5 + 10;
typedef pair<double, double> PII;
set<PII> st;
int ans;
int main()
{
	for(int x1 = 0; x1 <= 19; x1 ++)
	{
		for(int y1 = 0; y1 <= 20; y1 ++)
		{
			for(int x2 = 0; x2 <= 19; x2 ++)
			{
				for(int y2 = 0; y2 <= 20; y2 ++)
				{
					if(x1 == x2 || y1 == y2)continue;
					double k = ((y2 - y1) * 1.0) / ((x2 - x1) * 1.0);
					double b = ((x2 * y1 - x1 * y2) * 1.0) / ((x1 - x2) * 1.0);
					st.insert({k, b});
				}
			}
		}
	}
	ans = 41 + st.size();
	cout << ans;
	return 0;
}

故答案为40257

相关推荐
菜鸡儿齐13 分钟前
leetcode-电话号码的字母组合
算法·leetcode·职场和发展
小白菜又菜36 分钟前
Leetcode 229. Majority Element II
算法·leetcode·职场和发展
yzx9910133 小时前
蓝桥杯备考智能体:构建高并发、智能化编程竞赛助手的深度实践
职场和发展·蓝桥杯
期末考复习中,蓝桥杯都没时间学了4 小时前
力扣刷题23
算法·leetcode·职场和发展
菜鸡儿齐4 小时前
leetcode-括号生成
算法·leetcode·职场和发展
仰泳的熊猫5 小时前
题目1549:蓝桥杯算法提高VIP-盾神与积木游戏
数据结构·c++·算法·蓝桥杯
菜鸡儿齐6 小时前
leetcode-分割回文串
算法·leetcode·职场和发展
滴滴答滴答答6 小时前
LeetCode Hot100 之 19 接雨水
算法·leetcode·职场和发展
We་ct7 小时前
浏览器渲染流程(完整+面试背诵版)
前端·面试·职场和发展·edge·edge浏览器
香芋Yu17 小时前
【大模型面试突击】10_推理部署与优化
面试·职场和发展