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

建德网站建设公司泉州seo代理商

建德网站建设公司,泉州seo代理商,连云港做网站制作首选公司,佛山网站建设骏域网站建设专家题目描述 有 n 个人参加一个舞蹈课。每个人的舞蹈技术由整数来决定。在舞蹈课的开始,他们从左到右站成一排。当这一排中至少有一对相邻的异性时,舞蹈技术相差最小的那一对会出列并开始跳舞。如果不止一对,那么最左边的那一对出列。一对异性出…

题目描述

有 n 个人参加一个舞蹈课。每个人的舞蹈技术由整数来决定。在舞蹈课的开始,他们从左到右站成一排。当这一排中至少有一对相邻的异性时,舞蹈技术相差最小的那一对会出列并开始跳舞。如果不止一对,那么最左边的那一对出列。一对异性出列之后,队伍中的空白按原顺序补上(即:若队伍为 ABCD,那么 BC 出列之后队伍变为 AD)。舞蹈技术相差最小即是 ai​ 的绝对值最小。

任务是模拟以上过程,确定跳舞的配对及顺序。

输入格式

第一行一个正整数 n 表示队伍中的人数。

第二行包含 n 个字符 B 或者 GB 代表男,G 代表女。

第三行为 n 个整数 ai​。所有信息按照从左到右的顺序给出。

输出格式

第一行一个整数表示出列的总对数 k。

接下来 k 行,每行是两个整数。按跳舞顺序输出,两个整数代表这一对舞伴的编号(按输入顺序从左往右 1 至 n 编号)。请先输出较小的整数,再输出较大的整数。

输入输出样例

输入 #1复制

4
BGBG
4 2 4 3

输出 #1复制

2
3 4
1 2

说明/提示

对于 50% 的数据,1≤n≤200。

对于 100% 的数据,1≤n≤2×105,0≤ai​≤107

代码实现:

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

struct Pair {
    int idx1, idx2;
    int diff;
    bool operator<(const Pair& other) const {
        if (diff != other.diff) return diff < other.diff;
        return idx1 < other.idx1;
    }
};

int main() {
    int n;
    cin >> n;
    
    string genders;
    cin >> genders;
    
    vector<int> skills(n);
    for (int i = 0; i < n; i++) {
        cin >> skills[i];
    }
    
    vector<int> original_indices(n);
    for (int i = 0; i < n; i++) {
        original_indices[i] = i + 1;
    }
    
    vector<pair<int, int> > result;
    
    while (true) {
        vector<Pair> candidates;
        int current_size = genders.size();
        
        for (int i = 0; i < current_size - 1; i++) {
            if (genders[i] != genders[i + 1]) {
                Pair p;
                p.idx1 = i;
                p.idx2 = i + 1;
                p.diff = abs(skills[i] - skills[i + 1]);
                candidates.push_back(p);
            }
        }
        
        if (candidates.empty()) break;
        
        sort(candidates.begin(), candidates.end());
        Pair selected = candidates[0];
        
        int idx1 = selected.idx1;
        int idx2 = selected.idx2;
        
        result.push_back(make_pair(original_indices[idx1], original_indices[idx2]));
        
        genders.erase(idx1, 2);
        skills.erase(skills.begin() + idx1, skills.begin() + idx1 + 2);
        original_indices.erase(original_indices.begin() + idx1, original_indices.begin() + idx1 + 2);
    }
    
    cout << result.size() << endl;
    for (int i = 0; i < result.size(); i++) {
        int a = result[i].first;
        int b = result[i].second;
        cout << (a < b ? a : b) << " " << (a < b ? b : a) << endl;
    }
    
    return 0;
}

http://www.dtcms.com/wzjs/469918.html

相关文章:

  • 百度搜寻网站缩略图如何添加品牌公关公司
  • 海南网站推广建设重庆关键词seo排名
  • 即墨哪里有做网站的电商入门基础知识
  • 做网站前端用什么语言百度智能云建站
  • 南宁网站优化公司哪家好手机系统优化
  • 优质高等职业院校建设申报网站正规seo排名多少钱
  • 四川网站设计网站怎样做推广
  • 深圳网站软件开发发布软文的平台
  • 高陵网站建设百度关键词搜索热度
  • 北京网站制作公司飞沐网络营销的期末试题及答案
  • 响应式网站建设平台短视频seo优化
  • css怎么做响应式网站建站abc
  • 教人做饮料的网站网络公司名字
  • 郑州做网站hnqfu手游推广平台哪个好
  • inurl 网站建设网站seo优化检测
  • 做搜狗网站优化首页软网站关键词快速排名优化
  • 可靠的合肥网站建设百度刷seo关键词排名
  • 东莞英文网站制作企业qq手机版
  • 专门做app网站山西太原百度公司
  • 电子商务网站建设程序应用题无锡营销型网站制作
  • 域名 和网站有什么区别目前最牛的二级分销模式
  • 怎么看网站是否被收录seo网站培训优化怎么做
  • 网络营销网站建设流程公司网络推广服务
  • 动漫制作专业介绍心得体会200字哈尔滨优化调整人员流动管理
  • 北京建设信源资讯有限公司网站网页制作与设计教程
  • 什么是网站解决方案餐饮营销策划方案
  • 建筑挂靠十大网站seo域名如何优化
  • 西班牙语网站建设注意事项游戏推广平台哪个好
  • 柳州洛维建设网站必应搜索引擎国际版
  • 今日域名网站除了百度指数还有哪些指数