统一结果封装

简介: 统一结果封装

统一结果封装

Result的类,这个用于我们的异步统一返回的结果封装。一般来说,结果里面有几个要素必要的

  • 是否成功,可用code表示(如200表示成功,400表示异常)
  • 结果消息
  • 结果数据
import lombok.Data;
import java.io.Serializable;
@Data
public class Result implements Serializable {
    private int code; // 200是正常,非200表示异常
    private String msg; // 返回的信息
    private Object data; // 返回的数据
    public static Result succ(Object data) {
        return succ(200, "操作成功", data);
    }
    public static Result succ(int code, String msg, Object data) {
        Result r = new Result();
        r.setCode(code);
        r.setMsg(msg);
        r.setData(data);
        return r;
    }
    public static Result fail(String msg) {
        return fail(400, msg, null);
    }
    public static Result fail(String msg, Object data) {
        return fail(400, msg, data);
    }
    public static Result fail(int code, String msg, Object data) {
        Result r = new Result();
        r.setCode(code);
        r.setMsg(msg);
        r.setData(data);
        return r;
    }
}

小朋友的游戏(训练排序算法)

n 个小朋友在玩游戏,编号依次为 1∼n。

每个小朋友都有一个身份,为 rat(老鼠)、woman(女人)、child(孩子)、man(男人)、captain(舰长) 之一。

已知,这几种身份的优先级是有区别的:

rat 为第一优先级。

woman 和 child 为第二优先级。

man 为第三优先级。

captain 为第四优先级。

现在,要给小朋友们排队,排队的规则为:

对于不同优先级的小朋友,优先级越靠前(越小)则在队伍中的位置越靠前。

对于同一优先级的小朋友,编号越小则在队伍中的位置越靠前。

请你确定小朋友们的具体排队顺序。

输入格式:

第一行包含整数 n

接下来 n 行,其中第 i 行用来描述编号为 i 的小朋友,首先包含一个字符串,表示小朋友的名字,然后包含一个字符串,表示他的身份。

每个小朋友的名字都是一个长度范围在 [1,10] 的由英文字母构成的字符串,其中首字母大写,其余小写。

小朋友的名字两两不同。

表示身份的字符串一定是 rat、woman、child、man、captain 之一。

保证身份为 captain 的小朋友有且仅有一个。

输出格式:

共 n 行,其中第 i 行输出排在队伍中第 i 位的小朋友的名字。

输入样例:

6

Jack captain

Alice woman

Charlie man

Teddy rat

Bob child

Julia woman

输出样例:

Teddy

Alice

Bob

Julia

Charlie

Jack

数据范围

前 3 个测试点满足 1 ≤ n ≤ 10。

所有测试点满足 1 ≤ n ≤ 100。

算法解析

分析这个题,乍一看感觉还是蛮难的,不知道怎么进行排序,要求怎么这么多,然后在细想,好像可以做,就是用c++自带的类排序呀,定义一个类,然后这个类包含题目中要求的成员,然后在制定一个排序规则就好了,想好了之后就简单,这里我还做了一个小小的优化,就是使用map容器,对优先级进行了优化,把文字转换为了数字,这样更加方便于操作。

提交代码

#include<bits/stdc++.h>
using namespace std;
const int N = 1010;
map<string, int> mp;
class T{
    public:
        int num;
        string name;
        string name2;
    T(int num, string name, string name2)
    {
        this->num = num;
        this->name = name;
        this->name2 = name2;
    }
};
bool compare(T a, T b)
{
    if (mp[a.name2] == mp[b.name2])
    {
        return a.num < b.num;
    }
    else 
    {
        return mp[a.name2] < mp[b.name2];
    }
    // return true;
    return mp[a.name2] < mp[b.name2];
}
int main()
{
    int n;
    cin >> n;
    vector<T> v;
    mp.insert(make_pair("rat", 1));
    mp.insert(make_pair("woman", 2));
    mp.insert(make_pair("child", 2));
    mp.insert(make_pair("man", 4));
    mp.insert(make_pair("captain", 5));
    for (int i = 0; i < n; ++ i)
    {
        string name, name2;
        cin >> name >> name2;
        T t(i, name, name2);
        v.push_back(t);
    }
    sort(v.begin(), v.end(), compare);
    for (int i = 0; i < n; ++ i)
    {
        cout << v[i].name << '\n';
    }
    return 0; 
}


相关文章
|
12月前
|
JavaScript API
接口封装如何实现?
接口封装如何实现?
|
6月前
|
前端开发 JavaScript
前端项目公共组件封装思想
该文介绍了如何封装通用组件,如表单搜索、表格展示和分页器。首先,通过抽离出公共部分,创建`TableContainer`组件,利用具名插槽插入`navbar`和`table`,并通过props传递标题。然后在父组件中使用具名插槽和子组件实现具体功能。文中还展示了更复杂的组件封装示例,通过props实现数据双向绑定,以`el-pagination`为例,利用`sync`修饰符和`computed`属性监听并更新父组件状态,实现分页功能。文章最后提到了内容来源于哪。
102 0
|
4月前
|
存储 开发框架 前端开发
基于SqlSugar的开发框架循序渐进介绍(10)-- 利用axios组件的封装,实现对后端API数据的访问和基类的统一封装处理
基于SqlSugar的开发框架循序渐进介绍(10)-- 利用axios组件的封装,实现对后端API数据的访问和基类的统一封装处理
|
6月前
|
测试技术
封装并集中处理业务逻辑
封装并集中处理业务逻辑
38 1
|
6月前
|
消息中间件 设计模式 监控
如何优雅地实现接口统一调用?
【2月更文挑战第6天】
371 3
|
6月前
当需求范围不统一的时候该怎么办?
当需求范围不统一的时候该怎么办?
|
12月前
|
程序员 C++
论接口的封装能力
论接口的封装能力
48 0
|
设计模式 Linux C++
C++ 接口和实现分离初步简介
C++ 接口和实现分离初步简介
162 0
|
IDE Java Unix
统一开发工具配置
理论上无论使用哪个工具都可以,但是之前遇到过这样的情况,有人习惯使用 Eclipse 的自动格式化代码,每次提交代码都有一大堆的变化,仔细对比过后才发现仅是格式变化了,或是 improt 顺序变化了等等,多人提交代码时产生冲突,其实只是格式风险不一样,为了排除类似这样的困扰,使大家编码风格统一,所以,统一使用 IDEA 作为开发工具,代码格式和注释格式统一化。
|
开发者
业务层设计与开发(定义业务层标准) | 学习笔记
简介:快速学习业务层设计与开发(定义业务层标准)
138 0
业务层设计与开发(定义业务层标准) | 学习笔记