问题1

用来测试的,就不说了

问题2:中位数附近2k+1个数

给出一串整型数 a1,a2,...,a以及一个较小的常数 k,找出这串数的中位数 和最接近 的小于等于 的 k 个数,以及最接近 的大于等于 的 k 个数。将这 2k+1 个数按升序排序后输出。

中位数定义:如果数串的大小是偶数 2j,中位数是从小到大排列的第 j 个数;如果数串的大小是奇数 2j+1,中位数是从小到大排列的第 j+1 个数。

输入

第一行是 k 的值和数串的长度 n。

第二行是以空格隔开的 n 个整型数,最后一个数后面有空格。

输出

按升序排列的 2k+1 个数,以空格分开,最后一个数后面没有空格。结果可能出现重复的数。

思路

  这题如果直接排序再输出是会超时的,排序算法的复杂度为nlgn,后来按照快排的思想做通过了。

  先以快排的思想找出中位数,复杂度为n(递归方程为T(n)=T(n/2)+n,用代入法就可以证明),(由于快排是随机选取一个数做标准,所以我们在排完一次后需要判断所选标准和中位数的差距,接着在子区间内继续寻找中位数,选取到中位数后返回,具体看searchmid函数,应该写得很简洁了)

  按照快排的思想,我们已经将数组分为小于中位数的区间,中位数,大于中位数的区间。根据题目,所给的k很小,再根据选择排序的思想在左右两区间各选取k个数即可。

#include <iostream>
#include <vector>
#include <algorithm>
#include <limits.h>
using namespace std; //使用快速排序的思路,找出中间数,first和last为区间,pos为要寻找有序状态下的第几个数
int searchmid(vector<int>& v,int first, int last, int pos) {
int left = first;
int key = last;
for (int i = first; i <= last; ++i) {
if (v[i] < v[key]) {
swap(v[i], v[left]);
left++;
}
}
swap(v[left], v[key]);
if (left < pos)
return searchmid(v, left+, last, pos);
else if (left > pos)
return searchmid(v,first,left-,pos);
return left;
} int main()
{
int k,length;
cin >> k;
cin >> length;
vector<int> v(length,);
int pos = , num;
while (cin >> num) {
v[pos] = num;
pos++;
} /*int k = 0;
vector<int> v = {34, 10,9,8,7,6,5,4,3,2,1,0};
int length = v.size();*/ vector<int> result;
int index = searchmid(v, , length-, length/ - + length%);
//在数组前一部分寻找k个小于等于v[index]的数
for (int j = ; j < k; ++j) {
int max = INT_MIN;
int max_pos;
for (int i = ; i < index-j; ++i) {
if (v[i] > max) {
max = v[i];
max_pos = i;
}
}
swap(v[max_pos],v[index-j-]);
}
//在数组后一部分寻找k个大于等于v[index]的数
for (int j = ; j < k; ++j) {
int min = INT_MAX;
int min_pos;
for (int i = index + j + ; i < length; ++i) {
if (v[i] < min) {
min = v[i];
min_pos = i;
}
}
swap(v[min_pos],v[index+j+]);
}
for (int i = index - k; i <= index + k; i++) {
cout << v[i] ;
if (i != index + k)
cout << " ";
}
/*cout << endl; sort(v.begin(), v.end());
for (auto h : v)
cout << h << " ";
cout << endl; system("pause");*/
return ;
}

问题3:任意两数之和是否等于给定数

题目描述

给定一个 int 数组 arr,元素按照升序排列且各不相同。另外有一个目标数 c,请你找出 arr 中所有的数对 a, b,使得 a + b = c。

输入

输入为三行,第一行为 arr 的元素个数,第二行为 arr,元素以空格分隔,第三行为目标数 c。

输出

所有符合条件的数对 a, b。a 和 b 以空格分开,每个数对占据一行。每行中 a < b,所有数对以它的第一个数(也就是 a 的值)升序排列。

思路

直接遍历判断,符合条件的直接输出就可以了。

int main()
{
int length;
int target;
cin >> length;
vector<int> v(length, );
for (int i = ; i < length; ++i)
cin >> v[i];
cin >> target; for (int i = ; i < length;++i) {
for (int j = i + ; j < length; j++) {
if (v[i] + v[j] == target) {
cout << v[i];
cout << " ";
cout << v[j];
cout << endl;
}
}
} //system("pause");
return ;
}

南大算法设计与分析课程OJ答案代码(1)中位数附近2k+1个数、任意两数之和是否等于给定数的更多相关文章

  1. 南大算法设计与分析课程OJ答案代码(4)--变位词、三数之和

    问题 A: 变位词 时间限制: 2 Sec  内存限制: 10 MB提交: 322  解决: 59提交 状态 算法问答 题目描述 请大家在做oj题之前,仔细阅读关于抄袭的说明http://www.bi ...

  2. 南大算法设计与分析课程OJ答案代码(3)

    问题 A: 动态中位数问题 时间限制: 1 Sec  内存限制: 8 MB提交: 866  解决: 102提交 状态 算法问答 题目描述 输入一组整数a1, a2, …, an ,每输入一个整数,输出 ...

  3. 南大算法设计与分析课程OJ答案代码(5)--割点与桥和任务调度问题

    问题 A: 割点与桥 时间限制: 1 Sec  内存限制: 5 MB提交: 475  解决: 34提交 状态 算法问答 题目描述 给出一个无向连通图,找到所有的割点和桥 输入 第一行:点的个数,如果点 ...

  4. 南大算法设计与分析课程OJ答案代码(2)最大子序列和问题、所有的逆序对

    问题 A: 最大子序列和问题 时间限制: 1 Sec  内存限制: 4 MB提交: 184  解决: 66提交 状态 算法问答 题目描述 给定一整数序列 a1, a2, …, an,求 a1~an 的 ...

  5. 南大算法设计与分析课程复习笔记(1) L1 - Model of computation

    一.计算模型 1.1 定义: 我们在思考和处理算法的时候是机器无关.实现语言无关的.所有的算法运行在一种“抽象的机器”之上,这就是计算模型. 1.2 种类 图灵机是最有名的计算模型,本课使用更简单更合 ...

  6. 南大算法设计与分析课程复习笔记(4)L4 - QuickSort

    一.快速排序 算法导论上关于快速排序有两种写法 第一种,从头到尾遍历,不断将小于基准元素的项移到前面.代码很简介,只需要维护一个交换位置,表示小于基准元素的末尾位置加一 我们看算法导论上的一个例子: ...

  7. 南大算法设计与分析课程复习笔记(3)L3 - Recursion

    一.递归方程 按照分治的思想,可以将一个递归的复杂度写成递归方程 一.解递归方程--猜然后证明 该方法又称为代入法,步骤如下: 1.猜解的形式 2.数学归纳法证明正确 例子: 我们假设有如下递归式: ...

  8. 南大算法设计与分析课程复习笔记(2)L2 - Asymptotics

    一.几种比较复杂度的符号 数据结构有描述,相关严格数学定义也不想说了,就这么过了吧. 二.最大子数组的几种解决方法 从最复杂的暴力解法过渡到最简单的动态规划 解析和代码见这里:http://www.c ...

  9. 算法设计与分析 - AC 题目 - 第 5 弹(重复第 2 弹)

    PTA-算法设计与分析-AC原题 - 最大子列和问题 (20分) 给定K个整数组成的序列{ N1, N2, ..., NK },“连续子列”被定义为{ Ni, Ni+, ..., Nj },其中 ≤i ...

随机推荐

  1. python for data analysis 2nd 读书笔记(一)

    第一章相对简单,也么有什么需要记录的内容,主要用到的工具的简介及环境配置,粗略的过一下就行了.下面我们开始第二章的学习 CHAPTER 22.2Python Language Basics, IPyt ...

  2. _ZNote_Qt_按钮增加图片

    给Button添加图片方法 有三种 一 : 用代码添加 QPushButton *findBtn = new QPushButton(this); //创建按钮 QIcon ico (":/ ...

  3. JAVA数据结构之链表

    JAVA数据结构之链表 什么是链表呢? 链表作为最基本的数据结构之一,定义如下: 链表是一种物理存储单元上非连续.非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的. 简单来说呢,链 ...

  4. Vue route部分简单高级用法

    一改变页面title的值   在开发时常常需要在切换到不同页面时改变浏览器的title值,那么我们就可以在定义路由的时候通过配置 meta 属性 来改变title值. import Vue from ...

  5. Calendar and GregorianCalendar

    1.GregorianCalendar是Calendar的一个具体子类,提供了世界上大多数国家/地区使用的标准日历系统 2.注意 (1)月份:1月到12月[0-11] (2)星期:周日到周六[1-7] ...

  6. JAVA主流框架---SSM整合

      1.通过监听器的形式引入spring 2.SpringMVC容器和Spring容器间的关系 3.汇通的主旨 让大家熟练掌握SSM调用过程.并且将后台调用彻底掌握. 4.传统项目的搭建的弊端 1.传 ...

  7. Java 使用 Jxl 实现 Excel 导入导出

    开发过程中经常需要用到数据的导入导出功能,之前用的是POI,这次使用JXL,JXL相对于POI来说要轻量简洁许多,在数据量不大的情况下还是非常实用的.这里做一下使用JXL的学习记录.首先需要导入相应的 ...

  8. 细说MySQL表操作

    目录 语法 查看表结构 查看所有的表 删除表 查看创建表的语句 修改表的字符集和校验规则 修改表名 在表中添加新字段 修改表的字段名 修改表中字段的属性 删除表中的某个字段 设置某个字段为主键 把某个 ...

  9. 画线动画——SVG版和纯CSS版

    概述 我们常常在网站中看到一些画线的动画效果,非常炫酷,大多数这种画线动画效果是通过SVG实现的,也有不少是用纯css实现的,下面我总结了一下这2种方法,供以后开发时参考,相信对其他人也有用. 参考资 ...

  10. python2程序移植python3的一些注意事项

    1 queue: python2: import Queue python3: import queue 2 queue size: python2: cache = Queue.Queue(maxs ...