当前位置: 首页 > news >正文

江苏嘉瑞通建设有限公司网站wordpress 多说

江苏嘉瑞通建设有限公司网站,wordpress 多说,wordpress从零开始,深圳效果好的免费网站建设■ 题目描述 【磁盘容量排序】 磁盘的容量单位常用的有M,G,T这三个等级,它们之间的换算关系为1T 1024G,1G 1024M,现在给定n块磁盘的容量, 请对它们按从小到大的顺序进行稳定排序,例如给定5…

 题目描述

【磁盘容量排序】

磁盘的容量单位常用的有M,G,T这三个等级,它们之间的换算关系为1T = 1024G,1G = 1024M,现在给定n块磁盘的容量,

请对它们按从小到大的顺序进行稳定排序,例如给定5块盘的容量,1T,20M,3G,10G6T,3M12G9M排序后的结果为20M,3G,3M12G9M,1T,10G6T。

注意单位可以重复出现,上述3M12G9M表示的容量即为3M+12G+9M,和12M12G相等。

输入描述

输入第一行包含一个整数n(2 <= n <= 100),表示磁盘的个数,接下的n行,每行一个字符串(长度大于2,小于30),表示磁盘的容量,

由一个或多个格式为mv的子串组成,其中m表示容量大小,v表示容量单位,例如20M,1T,30G,10G6T,3M12G9M。

磁盘容量m的范围为1到1024的正整数,容量单位v的范围只包含题目中提到的M,G,T三种,换算关系如题目描述。

输出描述

输出n行,表示n块磁盘容量排序后的结果。

C语言

#include <bits/stdc++.h>#define CEILING_POS(X) ((X-(int)(X)) > 0 ? (int)(X+1) : (int)(X))
#define CEILING_NEG(X) ((X-(int)(X)) < 0 ? (int)(X-1) : (int)(X))
#define CEILING(X) ( ((X) > 0) ? CEILING_POS(X) : CEILING_NEG(X) )#define MIN(a, b) ((a) < (b)) ? (a) : (b)
#define MAX(a, b) ((a) > (b)) ? (a) : (b)int cmpfunc(const void *a, const void *b) {return (*(int *) a - *(int *) b);
}int convert(char *capacity) {int size = 0;char *upper = strdup(capacity);for (int i = 0; i < strlen(upper); i++) {upper[i] = toupper(upper[i]);}char *token = strtok(upper, "MGTP");while (token != NULL) {int num = atoi(token);char unit = upper[strlen(token)];switch (unit) {case 'M':size += num;break;case 'G':size += num * 1024;break;case 'T':size += num * 1024 * 1024;break;default:break;}token = strtok(NULL, "MGTP");}return size;
}int main() {int n;scanf("%d", &n);char **capacities = (char **) malloc(n * sizeof(char *));for (int i = 0; i < n; i++) {capacities[i] = (char *) malloc((20 + 1) * sizeof(char));scanf("%s", capacities[i]);}for (int i = 0; i < n; i++) {for (int j = i + 1; j < n; j++) {if (convert(capacities[i]) > convert(capacities[j])) {char *temp = capacities[i];capacities[i] = capacities[j];capacities[j] = temp;}}}for (int i = 0; i < n; i++) {printf("%s\n", capacities[i]);}return 0;
}

C++

示例1 输入输出示例仅供调试,后台判题数据一般不包含示例

输入

3

1G

2G

1024M

输出

1G

1024M

2G

说明

1G和1024M容量相等,稳定排序要求保留它们原来的相对位置,故1G在1024M之前。

示例2 输入输出示例仅供调试,后台判题数据一般不包含示例

输入

3

2G4M

3M2G

1T

输出

3M2G

2G4M

1T

说明

1T的容量大于2G4M,2G4M的容量大于3M2G。

#include <bits/stdc++.h>using namespace std;int getSize(string s)
{int ans = 0;int curNum = 0;for (char c: s) {if (isdigit(c)) {curNum = curNum * 10 + (c - '0');} else {if (c == 'M') {ans += curNum;} else if (c == 'G') {ans += curNum * 1024;} else if (c == 'T') {ans += curNum * 1024 * 1024;}curNum = 0;}}return ans;
}bool cmp(const string &s1, const string &s2)
{return getSize(s1) < getSize(s2);
}int main(int argc, const char *argv[])
{string s;int n;cin >> n;vector<string> size;while (n--) {cin >> s;size.push_back(s);}stable_sort(size.begin(), size.end(), cmp);for (string s: size) {cout << s << endl;}return 0;
}

http://www.yayakq.cn/news/427554/

相关文章:

  • 如何做公司介绍视频网站wordpress 安卓接口
  • 网站域名注册基本流程产品全网营销推广
  • 软件设计工作室网站企业网站首页设计原则
  • 做网站为什么差价很大北京建设工程交易协会网站
  • 网站建设黄页在线免费wordpress虎嗅网
  • 景德镇网站建设哪家好电商自学网免费
  • 如何管理wordpress网站模板下载怎么用织梦搭建网站
  • 商业网站制作价格阿里云建站中级版和高级版
  • 网站首页源码网站空间大小怎么查看
  • 深圳建设局投标网站网站建设论文源代码
  • 域名抢注网站源码wordpress gzip 插件
  • 建站之星视频阿里万网站建设
  • 做水产有什么网站网站制作2019趋势
  • 摄影网站建设的目的北京网址建设
  • 企业网站视频栏目建设方案自主建站是什么意思
  • 主机域名网站源码9k9k网页游戏开服表
  • 湖南网站营销推广上海专业网站建设咨询
  • 三点水网站建设合同杭州网站优化咨询
  • 网站快照长期不更新如何做淘宝cms导购网站
  • 深圳网站seo哪家快管理系统登录
  • 需要网站建设的人多吗国外黄冈网站推广软件
  • 手机版的网站怎样做呢python自学网站免费菜鸟教程
  • 网站域名购买卖鞋做哪个网站好
  • 有没有不花钱建设网站的方法wordpress安装无法登录
  • 呼和浩特网站建设公司兰州市住房和城乡建设厅官方网站
  • 网站开发的项目开发计划kfk wordpress
  • 手机兼职平台网站开发织梦导入wordpress
  • 网站后台是做什么的北京的建筑公司有哪些
  • 手机网站制作参考资料文献简单的ppt模板免费下载
  • 可以做配音兼职的网站家具设计软件下载