当前位置: 首页 > 编程日记 > 正文

【C++】用类来处理排序问题

运行环境:VS2017

由小到大排序

可以看出在主函数中所做的事:

(1)定义对象。

(2)向各对象发出“消息”,通知各对象完成有关任务。即调用有关对象的成员函数,去完成相应的操作。

(个人想法:如果有多个数组需要由小到大排序,使用类的话会比较方便吧,如果还是用C语言那种思路,每对一个数组排序,就要写一遍程序,这样会写大量的重复的代码,占空间,且可读性不强,如果使用类会方便很多!)

(3)主函数很简单,语句很少,大多数情况下,主函数中甚至不出现控制结构(判断结构和循环结构),而在成员函数中常会使用控制结构。

在面向对象的程序设计中,最关键的工作是类的设计。所有对数据的操作都体现在类中。

#include <iostream>
using namespace std;
class Array_sort
{
public:void set_value();void sort_value();void show_value();
private:int a[100];int n;
};
void Array_sort::set_value()
{cin >> n;for (int i = 0; i < n; i++){cin >> a[i];}
}
void Array_sort::sort_value()
{int i, j, k,t;for (i = 0; i < n - 1; i++){k = i;for (j = i + 1; j < n; j++){if (a[j] < a[k]){k = j;}}if (k != i){t = a[k]; a[k] = a[i]; a[i] = t;}}
}
void Array_sort::show_value()
{for (int i = 0; i < n; i++){cout << a[i] << " ";}cout << endl;
}
int main()
{Array_sort arr;arr.set_value();arr.show_value();arr.sort_value();arr.show_value();return 0;
}

相关文章:

winform 弹出窗体位置设定

[转]https://www.cnblogs.com/liushenglin/p/5350641.html 一、C#中弹出窗口位置 加入命名空间using System.Drawing和using System.Windows.Forms假定窗口名为form1,则 form1.StartPosition FormStartPosition.CenterScreen;窗体位置在屏幕中间form1.StartPosition FormSta…

pkg-config工具在实际工程中的用法

在如今这个开源的环境里&#xff0c;想要开发某个功能&#xff0c;我们都会下意识的上网搜索有没有开源库&#xff0c;如果有开源库&#xff0c;那么好&#xff0c;下载下来给它编译好&#xff0c;使用。但是在使用过程中&#xff0c;你是否遇到不知如何将第三方库编译&#xf…

linux中pipe

调用pipe函数时在内核中开辟一块缓冲区(称为管道)用于通信,它有一个读端一个写端,然后通过filedes参数传出给用户程序两个文件描述符,filedes[0]指向管道的读端,filedes[1]指向管道的写端(很好记就像0是标准输入1是标准输出一样)。所以管道在用户程序看起来就像一个打开的文通r…

【C++】利用构造函数对类对象进行初始化

运行环境&#xff1a;VS2017 一、对象的初始化 每一个对象都应当在它建立之时就有就有确定的内容&#xff0c;否则就会失去对象的意义。 class Time {int hour 0;int min 0;int sec 0; }; 这种是错误的&#xff0c;类并不是一个实体&#xff0c;并不占储存空间&#xff…

自定义Chrome浏览器

一、全局 自用备份&#xff0c;窗体透明化、要添加对应网站的窗体class到对应的位置 /*主页背景*/ /*https://images.cnblogs.com/cnblogs_com/AardWolf/1350846/o_5900399dcdcbd.jpg*/ /*https://ws4.sinaimg.cn/large/0072Vf1pgy1foxkfzphb2j31hc0u0gvv.jpg*/body { backgrou…

ubuntu添加sudo权限

使用如下命令可以添加到用户组&#xff08;也可是超级用户组&#xff09;。 命令如下&#xff1a; sudo usermod -aG 超级用户组名 用户名 例子&#xff1a;sudo usermod -aG sudo username 其中a:表示添加&#xff0c;G&#xff1a;指定组名第二种方法是直接修改&#xff0c…

File.separator

报告“No such file or diretory ”的异常&#xff0c;上传不了。后来发现是文件路径的问题。模拟测试环境是windowstomcat&#xff0c;而正式的的环境是linuxtomcat&#xff0c;文件路径的分隔符在windows系统和linux系统中是不一样。 比如说要在temp目录下建立一个test.txt文…

【C++】对象数组

运行环境&#xff1a;VS2017 对象数组&#xff1a;每个元素都是同类的对象 如果构造函数只有一个参数&#xff0c;在定义数组时可以直接在等号后面的花括号内提供实参。 Student stud[3]{60,70,80}; 如果构造函数有多个参数&#xff0c;则不能用在定义数组时直接提供所有实…

C# 算法系列一基本数据结构

一、简介 作为一个程序员,算法是一个永远都绕不过去的话题,虽然在大学里参加过ACM的比赛,没记错的话,浙江赛区倒数第二,后来不知怎么的,就不在Care他了,但是现在后悔了,非常的后悔!!!如果当时好好学算法的话,现在去理解一些高深的框架可能会很easy,现在随着C#基础和Web技能的提…

git管理大项目或者大文件

git 是追踪代码库演进的最佳选择&#xff0c;并且它能让你与你的同事间高效协作。当你想要追踪的库非常巨大时会发生什么&#xff1f;在这篇文章里&#xff0c;我会尝试着给你一些想法和技巧来恰当地处理不同种类的大仓库。两种大代码库如果仔细想想&#xff0c;大概会有两种导…

window下java开发环境安装

首先请去Java的官网上下载&#xff0c;最好下载最新版本地址&#xff1a;http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 如图&#xff0c;点击下载java platform&#xff08;JDK&#xff09;,然后选择接受接受协议&#xff08;Accept …

【ACM】蛇形填数

先判断&#xff0c;再移动&#xff0c;而不是发现越界了再退回来。 #include "stdio.h" #include "string.h" #define maxn 20 int a[maxn][maxn]; int main() {int n, x, y, tot 0;scanf_s("%d", &n);memset(a, 0, sizeof(a));tot a[x …

Mybatis中Oracle和Mysql的Count字段问题

Mybatis中Oracle和Mysql的Count字段问题 我们在进行项目开发时经常会碰到查询总数的问题&#xff0c;所以我们直接是用select count(1) from table来进行查询。那么在Mybatis通常情况下我们是这么写的 <select id"testCount" resultType"int">select…

为什么free()时不需要传指针大小

malloc()和free()是c中两个非常基本的函数&#xff0c;但这种最基本的东西往往都是特别复杂的。malloc和free的原形如下&#xff1a;void *malloc(unsigned int num_bytes); void free(void *ptr);在c的标准中并没有定义这两个函数的具体实现&#xff0c;在我们最常用的gcc中&a…

redis cluster 安装配置

一、redis集群安装配置1、下载redis源码包并下载wget http://download.redis.io/releases/redis-3.0.7.tar.gz $ tar xzf redis-3.0.7.tar.gz $ cd redis-3.0.7 yum -y install gcc gcc-c libstdc-devel #解决相关依赖关系$ make && make install 因我们安装redis 集…

【ACM】汉诺塔

https://blog.csdn.net/xueerfei008/article/details/9904681

什么是机器人底盘 答案在这里!

机器人底盘承载了机器人本身的定位、导航及避障等基本功能&#xff0c;可帮助机器人实现智能行走&#xff0c;以思岚科技的ZEUS为例&#xff0c;内置SLAMWARE高性能自主定位导航模块&#xff0c;用户可根据实际需要搭载不同的应用&#xff0c;可广泛适用于餐厅、商场、银行、办…

嵌入式linux内存使用和性能优化

这本书有两个关切点&#xff1a;系统内存(用户层)和性能优化。 这本书和Brendan Gregg的《Systems Performance》相比&#xff0c;无论是技术层次还是更高的理论都有较大差距。但是这不影响&#xff0c;快速花点时间简单过一遍。 然后在对《Systems Performance》进行详细的学…

【算法导论】插入排序

循环不变式 在数学上阐述了通过循环&#xff08;迭代&#xff0c;递归&#xff09;去计算一个累计的目标值的正确性。 关于循环不变式&#xff0c;我们必须要证明三条性质&#xff1a; 初始化&#xff1a;循环第一次迭代之前&#xff0c;它为真。保持&#xff1a;如果循环的…

gdb+gdbserver

内容摘要 远程调试环境由宿主机GDB和目标机调试stub共同构成&#xff0c;两者通过串口或TCP连接。使用 GDB标准程串行协议协同工作&#xff0c;实现对目标机上的系统内核和上层应用的监控和调试功能。调试stub是嵌入式系统中的一段代码&#xff0c;作为宿主机GDB和目标机调试程…

Android开发技巧——去掉TextView中autolink的下划线

我们知道&#xff0c;在布局文件中设置textview的autolink及其类型&#xff0c;这时textivew上会显示link的颜色&#xff0c;并且文字下面会有一条下划线&#xff0c;表示可以点击。而在我们在点击textview时&#xff0c;应用将根据我们所设置的类型跳转到对应的界面。但是有时…

【算法导论】冒泡排序 选择排序

冒泡排序&#xff1a; //从大到小 void bubble_sort(int array[],int len) {int i,j,t;for(i0;i<len-1;i){for(j0;j<len-1-i;j){if(array[j]<array[j1]){tarray[j];array[j]array[j1];array[j1]t;} }} } 选择排序&#xff1a; //从大到小 void select_sort(int a…

监控平台zabbix高级配置

2019独角兽企业重金招聘Python工程师标准>>> 12月26日任务 19.12 添加自定义监控项目 19.13/19.14 配置邮件告警 19.15 测试告警 19.16 不发邮件的问题处理 添加自定义监控项目 zabbix可以自定义监控项目&#xff0c;满足个性化的需求。例如网站注册量、访问量等具体…

linux内存实际占用分析

作者: 黄永兵/译 出处:51CTO.com 阅读提示&#xff1a;本文是为那些经常疑惑的人准备的&#xff0c;“为什么一个简单的KDE文本编辑器要占用25M内存&#xff1f;”导致大多数人认为许多Linux应用程序&#xff0c;特别是KDE或GNOME程序都象ps报告一样臃肿...【51CTO.com独家译文…

CentOS 6.5 下Vim 配置图解

分享个CentOS 6.5 下Vim 配置图文详解&#xff0c;希望对大家有所帮助。 1. 登录并进入你常用的用户名下&#xff0c;查看其主目录 命令&#xff1a; # su xxx $ cd xxx $ ls -a 2.查看并建立目录和文件 首先看你的主目录~/ 下是否有.vimrc文件&#xff0c;没有就输入指令 $ to…

【ACM】杭电OJ 1106 函数atoi

函数atoi是把字符串转化成整数的函数&#xff0c;头文件为 #include "stdlib.h" e.g. 运行环境&#xff1a;Dev-C 5.11 杭电1106 调用了sort函数&#xff0c;运行的时间相对长一些。 #include "stdio.h" #include "string.h" #include "…

docker-dockerfile

docker文件存储驱动dockerfile镜像构建指令示例dockekr镜像是只读的&#xff0c;对容器修改的内容&#xff0c;一旦容器退出&#xff0c;所有的内容将会丢失。镜像是分层的&#xff0c;最上的一层为读写层&#xff08;写时复制和用时分配&#xff09; 文件系统存储驱动&#xf…

proc/[pid]/maps 文件解释

proc/[pid]/maps 文件解释 查看进程的虚拟地址空间是如何使用的。 该文件有6列&#xff0c;分别为&#xff1a; 地址&#xff1a;库在进程里地址范围 权限&#xff1a;虚拟内存的权限&#xff0c;r读&#xff0c;w写,x,s共享,p私有&#xff1b; 偏移量&#xff1a;库在进程里…

【ACM】UVa 1339

【题目】&#xff1a;给定两个长度相同且不超过100的字符串&#xff0c;判断是否能把其中一个字符串的各个字母重排&#xff0c;然后对26个字母做一一映射&#xff0c;使得两个字符串相同。输入两个字符串&#xff0c;输出“YES”或者“NO”。 【分析】&#xff1a;既然字母可…