蓝桥杯刷题()第一天

1.位运算:
道理就不解释了直接看代码,具体源代码和题目直接留言就好了
具体代码和截图在下面
在这里插入图片描述
在这里插入图片描述
题目一:
找出一个数字里面一的个数,比如3(11)输出2
代码:
利用位运算
法一(每次往右边移动,每次移动一次就加上去)

#include <iostream>
using namespace std;
int main()
{
	int n,count=0;
	cin>>n;
	while(n)
	{
		if(n&1==1) count++;//如果当前位置是1就加上去 
		n>>=1;//把当前数字拿去移动,每次移动一格 
		
	}
	cout<<count<<endl;
	return 0;
 } 

法二:将0000000000…1移动32次,32正好是一个int表示的大小
枚举32位所有可能,每次枚举的时候,除了该位是1其他位置都是0,所以每次判断是否&后和生成的这个数一样

#include <iostream>
using namespace std;
int main()
{
	int n,count=0;
	cin>>n;
	for(int i=0;i<32;++i)
	{
		if(((1<<i)&n)==(1<<i))
		{
			count++;
		}
	 }
	 cout<<count<<endl;
	 return 0; 

 } 

法三:我们思考这样的一个东西,我们模拟数1,每次数到一个1就记录消除这个1,那么我们消除几次这个1就代表我们有几个1;
这样想的话很简单;我们每次把这个数n和(n-1)进行&运算就好了
比如5是101
101 (-)1是 100 &101后就是100
100(-)1是 011 &100后就是000
结束 操作了2次就2个
代码:

#include <iostream>
using namespace std;
int main()
{
	int n,count=0;
	cin>>n;
	while(n)
	{
		n=n&(n-1);
		count++;
	}
	 cout<<count<<endl;
	 return 0; 

 } 

题目:设计一个算法,计算出n阶乘中尾部零的个数
思路:尾部的0要如何计算呢,尾巴的0是如何出来的呢,就是因为10出来的,10就是2*5的乘积;5的个数就是次数;
代码:

public static long trailingZeros(long n) {
	    int count=0; 
	    while(n!=0)//如果n还有的话,就继续除
	    {
	    	n/=5;//计算当前5的个数还有多少个
	    	count+=n;//加进去这个数
	    }
		return count;
	  }

题目:写一个程序来检测一个整数是不是丑数。

丑数的定义是,只包含质因子 2, 3, 5 的正整数。比如 6, 8 就是丑数,但是 14 不是丑数因为他包含了质因子 7。
代码:

public class Solution {
    /**
     * @param num: An integer
     * @return: true if num is an ugly number or false
     */
    public boolean isUgly(int num) {
        if(num<=0) return false;
        while(num!=1)
        {
            if(num%2==0)//如果num对2,3,5除得尽就除掉,如果除不掉就return false
            
            {
                num/=2;
            }
            else if(num%3==0)
            {
                num/=3;
            }
            else if(num%5==0)
            {
                num/=5;
            }
            else return false;
        }
        return true;
    }
}

题目:
判断一个数字是不是2的次方:
代码:

#include <iostream>
#include <algorithm>
using namespace std;
int a[10010];
int main()
{
	int n,i=0;
	cin>>n;
	while(n)
	{
		if(n&1==1) i++;
		n>>=1;
		
	}
	
	if(i==1) cout<<"yes";
	else cout<<"no";
	return 0;
 } 
#include <iostream>
#include <algorithm>
using namespace std;
int a[10010];
int main()
{
	int n,i=0;
	cin>>n;
	if(n&(n-1)==0) cout<<"yes"<<endl;//第一次&一下就是0的话,证明只有一个1 
	else cout<<"no"<<endl;
	return 0;	

 } 
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
int a[10010];
int main()
{
	double a;
	int sum=0;
	string s;
	cin>>a;
	s+="0.";
	while(a>0)
	{
		double aa=a*2;
		if(aa>=1.0)
		{
			s+="1";
			a=aa-1.0;
		}
		else if(aa<1)
		{
			a=aa;
			s+="0";
		}
		sum++;
		if(sum>32)
		{
			cout<<"not"<<endl;
			return 0;
		}
		
	 } 
	 cout<<s<<endl;
	 return 0;
	 

 } 

这里补充一个重点的二进制;
二进制如何表示浮点数;
比如表示0.625;
乘2消整法:
0.6252=1.25
消除整数位1
输出1;
变成0.25
0.25
2=0.5;
输出0
0.5*2=1;
输出1;
消1
变为0
所以就是0.101;
代码:

#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
int a[10010];
int main()
{
	double a;
	int sum=0;
	string s;
	cin>>a;
	s+="0.";
	while(a>0)
	{
		double aa=a*2;
		if(aa>=1.0)
		{
			s+="1";
			a=aa-1.0;
		}
		else if(aa<1)
		{
			a=aa;
			s+="0";
		}
		sum++;
		if(sum>32)
		{
			cout<<"not"<<endl;
			return 0;
		}
		
	 } 
	 cout<<s<<endl;
	 return 0;
	 

 } 
<think>好的,我现在要处理用户关于“蓝桥杯Python一周速成”的查询。首先,我需要理解用户的需求。用户可能是在短时间内需要准备蓝桥杯Python组的比赛,时间紧迫,所以希望得到高效的学习策略和重点内容。 接下来,我应该考虑蓝桥杯Python组的考察范围。通常这类比赛会涉及基础语法、算法数据结构,以及实际问的解决能力。由于时间只有一周,用户不可能深入所有细节,因此需要筛选出高频考点和容易快速掌握的内容。 然后,我得规划出一周的学习计划。每天安排不同的主,比如第一天基础语法,第二天数据结构,第三天算法入门,第四天真训练,第五天模拟,第六天查漏补缺,第七天复习调整。每个主需要突出重点,例如基础语法中的循环、条件判断、函数;数据结构中的列表、字典、字符串处理;算法部分如排序、递归、动态规划基础。 还要考虑用户可能的基础情况。如果用户已经有一定Python基础,重点应放在算法和真训练上;如果是零基础,可能需要更紧凑的安排,但一周时间确实紧张。不过用户提到“速成”,所以假设有一定的基础,但需要系统复习和强化。 然后,需要给出具体的学习建议。例如推荐哪些资源,官方库的重要性,时间分配策略,以及调试能力的培养。同时提醒用户避免的误区,比如不要死记硬背代码,或者忽视真。 可能遇到的问是如何在短时间内高效掌握关键算法。这时候需要推荐常见的算法型,如排序、查找、简单动态规划,并提供典型例,比如斐波那契数列、背包问等。但要注意复杂度,避免过于复杂的内容。 最后,总结部分需要鼓励用户,强调合理规划和专注的重要性,同时提醒调整心态,保持良好状态参赛。可能还需要提醒用户注意比赛规则和环境,比如蓝桥杯使用的评测系统,编程环境的熟悉等。 检查是否有遗漏点,比如是否需要提到具体的参考资料或在线资源?用户可能希望得到推荐的练习平台,比如蓝桥杯官网、LeetCode简单、牛客网等。是否需要包含这些信息?根据用户的问,可能不需要太具体的推荐,但给出一般性建议是合适的。 另外,确保回答结构清晰,分点明确,符合用户可见层的指令要求。使用中文,避免专业术语过于晦涩,同时保持逻辑连贯,帮助用户一步步解决问。 现在需要将这些思考整理成一个结构化的回答,涵盖每日计划、重点内容、学习建议、注意事项等,确保用户能在一周内高效备考。</think>以下是针对蓝桥杯Python组**一周速成计划**的详细指南,结合高频考点和短期突破策略: --- ### **一、核心考点与优先级** 蓝桥杯Python组侧重**算法实现能力**和**实际问建模**,重点掌握以下内容(按优先级排序): 1. **基础语法**:输入输出(`input()`格式化处理)、列表推导式、字符串操作(切片、`split()`/`join()`) 2. **数据结构**:列表(排序、二维数组操作)、字典(计数、映射)、集合(去重) 3. **算法**: - **必考**:贪心算法(找零、活动选择)、DFS/BFS基础(迷宫问)、动态规划(一维DP,如爬楼梯) - **高频**:排序(冒泡、快速排序)、递归(阶乘、斐波那契)、数学问(质数判断、进制转换) 4. **真型**:日期计算、字符串处理、图论基础(最短路径简化版) --- ### **二、7天速成计划表** #### **Day 1-2:语法与数据结构突击** - **上午**: - 输入输出:处理多行输入(如`sys.stdin.read()`),格式化输出(`f-string`对齐) - 列表操作:合并`extend()`、排序`sorted(key=lambda)`、二维列表遍历(矩阵转置) - **下午**: - 字典应用:统计词频(`collections.defaultdict`)、键值反转 - 字符串技巧:`replace()`链式处理、正则表达式简单匹配(如`re.findall(r'\d+',s)`) #### **Day 3-4:算法入门与模板记忆** - **贪心算法**: - 典型:硬币找零(优先大面值)、区间调度(按结束时间排序) - **DFS/BFS**: - 模板代码:迷宫路径计数(使用栈/队列)、岛屿问 - **动态规划**: - 一维DP:背包问(01背包简化版)、最长递增子序列(`O(n^2)`解法) #### **Day 5-6:真实战与调试技巧** - **策略**: - 近3年初赛真(官网/库),限时90分钟模拟 - 重点型:日期类(闰年判断、星期计算)、数学逻辑(等差数列求和、质因数分解) - **调试技巧**: - 使用`print`定位错误(输出中间变量) - 边界测试:输入为空、极值(如n=0或1e5) #### **Day 7:查漏补缺与策略优化** - **易错点回顾**: - 循环边界错误(如`range(n)` vs `range(1,n+1)`) - 深拷贝/浅拷贝问(二维列表使用`copy.deepcopy()`) - **时间分配策略**: - 简单30分钟内AC,难先写伪代码保部分分 --- ### **三、推荐资源与工具** 1. **练习平台**:蓝桥杯官方练习系统、洛谷(筛选“普及-”难度) 2. **代码模板**:整理DFS/BFS、快速排序等高频算法模板(手写记忆) 3. **效率工具**:使用Python内置函数(如`itertools.permutations`生成排列) --- ### **四、注意事项** - ❌ 避免死磕复杂算法(如线段树、网络流) - ✅ 考试时优先提交**部分正确**的代码(蓝桥杯按用例给分) - ✅ 注意Python特性:大整数运算无需优化,但递归深度默认限制(可设置`sys.setrecursionlimit`) --- 通过**真驱动学习+模板化训练**,即使时间紧张也能有效提升应试能力。最后一天保持良好作息,调整心态应对比赛!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值