排序检索 299 train swapping
来源:互联网 发布:pudn程序员 编辑:程序博客网 时间:2024/06/07 08:55
题目大意:相邻元素翻转,直到数组升序排列
解题过程:一次AC
正确代码:
# include <cstdio># include <cstdlib># include <ctime># include <cmath># include <iostream># include <fstream># include <cstring># include <string>//*#define fin cin#define fout cout//*/using namespace std;/*ifstream fin("in.txt");ofstream fout("out.txt");//*/int cmp(const void*a,const void*b){return *(int*)a-*(int*)b;}int order[100];int car[100];int main(){int n,l;fin>>n;int cases=0;while(cases<n){cases++;int num=0;bool tochange=true;fin>>l;for(int i=0;i<l;i++){fin>>car[i];order[i]=car[i];} qsort(order,l,sizeof(order[0]),cmp);for(int i=0;i<l;i++){if(order[i]!=car[i]){int target;for(int j=i;j<l;j++){if(car[j]==order[i]){target=j;//fout<<"待调整位置:"<<target<<"调整到位置:"<<i<<endl;num+=j-i;break;}}for(int j=i;j<=target;j++){int temp=car[j];car[j]=car[target];car[target]=temp;}}}fout<<"Optimal train swapping takes "<<num<<" swaps."<<endl;} return 0; }
0 0
- 排序检索 299 train swapping
- 排序/查找 299 - Train Swapping
- UVA 299 - Train Swapping(冒泡排序)
- UVA 299 Train Swapping(冒泡排序)
- UVa 299 Train Swapping
- Uva 299 Train Swapping
- uva 299 Train Swapping
- UVA 299 - Train Swapping
- 299 - Train Swapping
- UVA 299-Train Swapping
- UVa 299 - Train Swapping
- uva-299 - Train Swapping
- 299 - Train Swapping
- UVa 299 - Train Swapping
- UVaOJ 299 - Train Swapping
- UVa 299 - Train Swapping
- 299 - Train Swapping
- 299 - Train Swapping
- Sending Simple Data to Other Apps
- linux 测验(二) 知识点
- Python中的局部和全局变量
- Node学习课程(2)——新建工程
- Android开发之WebView知识和常见问题
- 排序检索 299 train swapping
- Fiddler 教程
- 深度学习算法实践6---逻辑回归算法应用
- 沈文超的简历-.net 软件工程师
- 硬币问题总结
- (java链表)实现队列(望高人指点)
- 【ECC小技巧】SAP 系统图标名称
- Android如何让Fragment加载到Activity中
- android 防止快速点击问题