按位与例题

需求:

给你一个整数数组 arr 。请你将数组中的元素按照其二进制表示中数字 1 的数目升序排序。

如果存在多个数字二进制中 1 的数目相同,则必须将它们按照数值大小升序排列

来自:位运算之按位与-CSDN博客

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>




void sort_accord_num_of_2radix(int*, int*, int);

int* num_of_2radix(int*, int);
int main() 
{
    int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
    int len_arr = sizeof(arr) / sizeof(int);    // ptr_array = num_of_2radix(arr, len_arr);     int array[10] = { 1,1,2,1,2,2,3,1,2,2 };

    int* ptr_array =num_of_2radix(arr, len_arr);
    sort_accord_num_of_2radix(ptr_array, arr, len_arr); 

    return 0;
}

void sort_accord_num_of_2radix(int* array, int* arr, int len_arr) 
{
    for (int i = 9; i > 0; i--) 
    {
        for (int j = 0; j < i; j++) 
    {
            int tem_array = 0, tem_arr = 0;

            if (array[j] > array[j + 1])
             {
                tem_array = array[j];
                array[j] = array[j + 1];
                array[j + 1] = tem_array;
                tem_arr = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = tem_arr;
            }
        }
    }
    for (int k = 0; k < 10; k++) 
    {
        printf("array[%d]=%d ", k, array[k]);        
        printf("arr[%d]=%d\n", k, arr[k]);
    }

}

int* num_of_2radix(int* arr, int len_arr) 
{
    int* ptr_2radix_num = (int*)malloc(sizeof(int) * len_arr);
    for (int  r= 0;  r< 10; r++) 
    {       //遍历arr所有元素
        int sentry = 1, d = 0;          //0001用于扫描
        for (int s = 0; s < 16; s++) 
        {
            if ((arr[r] & sentry)) 
            {
                d++;
            }
            sentry=sentry << 1;   // printf("sentry=%d\n", sentry);
        }
        ptr_2radix_num[r] = d;
    }

    for (int a = 0; a < len_arr; a++) 
    {
        printf("ptr_2radix_num[%d]=%d\n", a, ptr_2radix_num[a]);
    }
    return ptr_2radix_num;
}
相关推荐
浅念同学6 分钟前
算法.图论-并查集上
java·算法·图论
何不遗憾呢14 分钟前
每日刷题(算法)
算法
立志成为coding大牛的菜鸟.19 分钟前
力扣1143-最长公共子序列(Java详细题解)
java·算法·leetcode
鱼跃鹰飞19 分钟前
Leetcode面试经典150题-130.被围绕的区域
java·算法·leetcode·面试·职场和发展·深度优先
liangbm325 分钟前
数学建模笔记——动态规划
笔记·python·算法·数学建模·动态规划·背包问题·优化问题
潮汐退涨月冷风霜30 分钟前
机器学习之非监督学习(四)K-means 聚类算法
学习·算法·机器学习
B站计算机毕业设计超人36 分钟前
计算机毕业设计Python+Flask微博情感分析 微博舆情预测 微博爬虫 微博大数据 舆情分析系统 大数据毕业设计 NLP文本分类 机器学习 深度学习 AI
爬虫·python·深度学习·算法·机器学习·自然语言处理·数据可视化
羊小猪~~40 分钟前
深度学习基础案例5--VGG16人脸识别(体验学习的痛苦与乐趣)
人工智能·python·深度学习·学习·算法·机器学习·cnn
ahauedu42 分钟前
案例分析-Stream List 中取出值最大的前 5 个和最小的 5 个值
数据结构·list
X同学的开始3 小时前
数据结构之二叉树遍历
数据结构