算法-计算机基础知识

1,坐标系与数学不同,x轴向下,y轴向右

2.案例:螺旋矩阵

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

java 复制代码
class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {
List<Integer> res=new ArrayList();
int n=matrix.length;//有多少行
if(n==0) return res;
int m=matrix[0].length;//列

//设定方向向量,要顺时针,右下左上
int dx[]={0,1,0,-1},dy[]={1,0,-1,0};
//判断当前的数组有没有被使用,也就是有没有加到答案数组中
boolean st[][]=new boolean[n][m];

//x和y表示的是当前循环到了哪个坐标,dir表示当前的方向
for(int i=0,x=0,y=0,dir=0;i<n*m;i++){
    res.add(matrix[x][y]);//将数字加入答案数组中
    st[x][y]=true;//说明当前数字已经被使用
    int a=x+dx[dir],b=y+dy[dir];
//循环方向
    for(int j=0;j<4;j++){

        if(a<0||a>=n||b<0||b>=m||st[a][b]){
            dir=(dir+1)%4;
            a=x+dx[dir];
            b=y+dy[dir];

        }
    }
    x=a;
    y=b;
}
return res;
    }
}

位运算

注意,位运算的优先级比加减乘除低,所以加括号

. - 力扣(LeetCode)

在[a,b] 取a` b`

a` & b`,得到c`,此时那c去和[a,b]所有数&结果全是c

在精简一下,如果a=01001,b=11101,那a`=01111,b`=10000,c=00000ans就是0

也就是说只要最高位不同ans一定为0,再推广,从高位往地位看,只要高位不全是1,直接为0

java 复制代码
class Solution {
    public int rangeBitwiseAnd(int left, int right) {
        int res=0;
        for(int i=30;i>=0;i--){
            if((left>>i&1)!=(right>>i&1)) break;//取第i位判断是否相等,不相等答案就是0
           if((left>>i&1)==1)  res+=1<<i;
        }
        return res;
    }
}
相关推荐
数据皮皮侠8 分钟前
2285 上市公司组织衰退程度【Dec】2010-2024
大数据·人工智能·算法·制造
daxi15010 分钟前
C语言从入门到进阶——第17讲:字符串函数
c语言·开发语言·算法·蓝桥杯
wljy113 分钟前
第十四届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(个人见解,已完结)
c语言·c++·算法·蓝桥杯
CoderCodingNo16 分钟前
【GESP】C++八级考试大纲知识点梳理 (7) 算法的时间和空间效率分析
开发语言·c++·算法
青瓷程序设计21 分钟前
基于YOLO的安全帽佩戴检测系统~Python+模型训练+2026原创+YOLO算法
python·算法·yolo
Trouvaille ~21 分钟前
【优选算法篇】拓扑排序——逻辑先后与任务依赖的终极拆解
数据结构·c++·算法·leetcode·青少年编程·蓝桥杯·拓扑学
T1an-124 分钟前
博乐科技笔试题
科技·算法
XiYang-DING30 分钟前
【LeetCode】118.杨辉三角
算法·leetcode·职场和发展
wuhen_n37 分钟前
排列算法完全指南 - 从全排列到N皇后,一套模板搞定所有排列问题
前端·javascript·算法
ai生成式引擎优化技术41 分钟前
拓世网络技术开发工作室的ts概率递推ai工程应用技术GEOChatGPT,不同用户账号信息,网站引用效果
算法