• 算法笔记,


    一 位1的个数

     代码:

    1. public class Solution {
    2. // you need to treat n as an unsigned value
    3. public int hammingWeight(int n) {
    4. int num = 0;
    5. for (int i = 0; i < 32; i++) {
    6. if ((n & (1 << i)) != 0) {
    7. num++;
    8. }
    9. }
    10. return num;
    11. }
    12. }

    思路: 判断一个数字x二进制下第i位是否为1可以用if(((1<<(i-1))&x)将1左移i-1位,得到的数只有第i位是1,其他位都是0的二进制数,然后与输入的数做与运算,只有当n的第i位为1得到的解果才不为0,这样就可以判断n的第i位是否为1。

     二  扬辉三角 

    1. class Solution {
    2. public List<List<Integer>> generate(int numRows) {
    3. List<List<Integer>> out=new ArrayList<List<Integer>>();
    4. for(int i=0;i<numRows;i++) {
    5. List<Integer> in=new ArrayList<Integer>();
    6. for(int j=0;j<=i;j++) {
    7. if(j==0||j==i) {
    8. in.add(1);
    9. }
    10. else {
    11. in.add(out.get(i-1).get(j-1)+out.get(i-1).get(j));
    12. }
    13. }
    14. out.add(in);
    15. }
    16. return out;
    17. }
    18. }

     此题中每行左右两个数都是1,第 n行的第 i个数等于第 n−1 行的第 i−1 个数和第 i个数之和

    三 只出现一次的数字

    1. class Solution {
    2. public int singleNumber(int[] nums) {
    3. int a=0;
    4. for(int i:nums){
    5. a^=i;
    6. }
    7. return a;
    8. }
    9. }

    思路: 此题运用到异或运算的性质。任何数和 0 做异或运算,结果仍然是原来的数;任何数和其自身做异或运算,结果是 0;异或运算满足交换律和结合律,即a^b^a=b^(a^a)=b^0=b;

    所以遍历数组中所有数让它们做异或运算,由于除了一个数其他两个数都出现两次,所以所有数异或得到的结果就是只出现一次的那个数!

     

  • 相关阅读:
    UIStackView入门使用两个问题
    Java版工程行业管理系统源码-专业的工程管理软件- 工程项目各模块及其功能点清单
    Leetcode150二刷总结
    Debian11安装Proxmox VE 7
    RIP动态路由协议详解
    【2023/10/16 下午10:32:39】
    高速自动驾驶HMI人机交互
    solidity Foundry开发工具
    vue el-button 封装及使用
    Linux环境下C++ 接入OpenSSL
  • 原文地址:https://blog.csdn.net/qq_62401904/article/details/125597988