整型数组按个位值排序/最低位排序(C语言)

news/2024/7/20 18:14:32 标签: c语言, 华为od, 数据结构, 算法

题目描述

给定一个非空数组(列表),其元素数据类型为整型,请按照数组元素十进制最低位从小到大进行排序,十进制最低位相同的元素,相对位置保持不变。
当数组元素为负值时,十进制最低位等同于去除符号位后对应十进制值最低位。

输入描述

  • 给定一个非空数组,其元素数据类型为32位有符号整数,数组长度[1, 1000]

输出描述

  • 输出排序后的数组

用例

输入1,2,5,-21,22,11,55,-101,42,8,7,32
输出1,-21,11,-101,2,22,42,32,5,55,7,8
说明
输入19,-31,10,57,61,27,11,28,-94
输出10,-31,61,11,-94,57,27,28,19
说明

代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

// 获取数字的十进制最低位
int getKey(int num) {
    num = abs(num); // 去除符号
    return num % 10;
}
int cmp(const void *a, const void *b) {
    return getKey(*(int *)a) - getKey(*(int *)b);
}

int main() {
    char input[1000];
    fgets(input, 1000, stdin);
    input[strcspn(input, "\n")] = '\0';

    char *token = strtok(input, ",");
    int nums[1000];
    int count = 0;
    while (token != NULL) {
        nums[count++] = atoi(token);
        token = strtok(NULL, ",");
    }

    qsort(nums, count, sizeof(int), cmp);
    for (int i = 0; i < count; i++) {
        printf("%d", nums[i]);
        if (i < count - 1) {
            printf(",");
        }
    }

    return 0;
}


http://www.niftyadmin.cn/n/5385025.html

相关文章

51_蓝桥杯_独立按键

一 电路 注意&#xff1a;J5跳帽接到2~3引脚&#xff0c;使按键S4-S5四个按键的另外一端接地&#xff0c;从而成为4个独立按键。 二 独立按键工作原理 三 代码 代码1&#xff1a;按下S7点亮L1指示灯&#xff0c;松开按键&#xff0c;指示灯熄灭&#xff0c;按下S6点亮L2指示灯…

iview 页面中判断溢出才使用Tooltip组件

使用方法 <TextTooltip :content"contentValue"></TextTooltip> 给Tooltip再包装一下 <template><Tooltip transfer :content"content" :theme"theme" :disabled"!showTooltip" :max-width"300" :p…

java如何做视频抽帧,视频转图片操作Demo

java如何做视频抽帧,视频转图片操作Demo!现在市面上很多客户提成需求&#xff0c;希望可以把本地的视频&#xff0c;抽帧&#xff08;一个一个静态的图片&#xff09;。至于为什么要抽帧&#xff0c;大家自己去百度查询。我们本次仅仅讨论如何使用java技术&#xff0c;实现视频…

Aidex移动端项目入门

运行效果 项目源码下载 若依-ruoyi-AiDex-Uniapp: 若依-Ruoyi APP 移动解决方案&#xff0c;基于uniappuView封装的一套基础模版&#xff0c;开箱即用&#xff0c;免费开源&#xff0c;一份代码多终端适配&#xff0c;支持H5、支付宝小程序、微信小程序、APP&#xff0c;实现了…

C#,笛卡尔树(Cartesian Tree)的构造、遍历算法与源代码

Ren Descartes 一、笛卡尔&#xff08;Ren Descartes&#xff09; 勒内笛卡尔&#xff08;Ren Descartes&#xff0c;1596年3月31日-1650年2月11日&#xff09;&#xff0c;1596年3月31日生于法国安德尔-卢瓦尔省的图赖讷&#xff08;现笛卡尔&#xff0c;因笛卡尔得名&#…

微信小程序的双向数据绑定和vue的哪里不一样?下拉刷新的方式代码示例

小程序的双向数据绑定和Vue的双向数据绑定有一些不同之处。 实现方式&#xff1a;小程序的双向数据绑定采用的是数据劫持的方式&#xff0c;通过重写对象的get和set方法来监听数据的变化和更新视图。而Vue使用的是响应式数据的方式&#xff0c;通过使用Object.defineProperty()…

Springboot项目的run debug都是灰色解决方法

IDEA下新建SpringBoot项目后&#xff0c;问题显示如下&#xff1a; 解决方法如下&#xff1a; 这个问题是由于缺少Configuration构建器的原因&#xff0c;因此&#xff1a; 1.点击Add Configuration 添加Spring Boot构建器&#xff0c;启动类选择好&#xff0c;点击确认即可&a…

vue2中几种组件传值方法

1.父子组件传值 父组件在子组件标签中传入fatherMess,在子组件使用$emit,约定子传父事件名,将子组件的数据传递到父组件.通过按钮修改,可以发现,这里的传值是响应式的 步骤: ​ 1.在父组件中给子组件标签添加属性 ​ 2.在子组件中使用props接受数据 ​ 3.子组件中使用数据,…