(每日一练c++)CC201 数组中的逆序对

前言

C++是一种计算机高级程序设计语言,由C语言扩展升级而产生 ,最早于1979年由本贾尼·斯特劳斯特卢普在AT&T贝尔工作室研发。 
C++既可以进行C语言的过程化程序设计,又可以进行以抽象数据类型为特点的基于对象的程序设计,还可以进行以继承和多态为特点的面向对象的程序设计。C++擅长面向对象程序设计的同时,还可以进行基于过程的程序设计。
C++拥有计算机运行的实用性特征,同时还致力于提高大规模程序的编程质量与程序设计语言的问题描述能力。

Java是一门面向对象的编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程 。
Java具有简单性、面向对象、分布式、健壮性、安全性、平台独立与可移植性、多线程、动态性等特点 。Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等 。

Python由荷兰数学和计算机科学研究学会的吉多·范罗苏姆 于1990 年代初设计,作为一门叫做ABC语言的替代品。Python提供了高效的高级数据结构,还能简单有效地面向对象编程。Python语法和动态类型,以及解释型语言的本质,使它成为多数平台上写脚本和快速开发应用的编程语言,随着版本的不断更新和语言新功能的添加,逐渐被用于独立的、大型项目的开发。
Python解释器易于扩展,可以使用C语言或C++(或者其他可以通过C调用的语言)扩展新的功能和数据类型。Python 也可用于可定制化软件中的扩展程序语言。Python丰富的标准库,提供了适用于各个主要系统平台的源码或机器码。
2021年10月,语言流行指数的编译器Tiobe将Python加冕为最受欢迎的编程语言,20年来首次将其置于Java、C和JavaScript之上。

描述

描述

给定一个int数组A和它的大小n,对于这组数能组成的任意两个数组,若前面一个大于后面一个数字,则这两个数字组成一个逆序对。请设计一种高效的算法返回A中存在的逆序对个数。要求n不大于5000。

测试样例:

[1,2,3,4,5,6,7,0],8
返回:7
/*
冒泡排序时做了多少次交换就有多少个逆序
*/
class AntiOrder {
public:
    int count(vector<int> A, int n) {
        // write code here
        int count = 0;
        int i,j;
        if(n < 2) return n;
        for(i=0;i<n;i++){
            for(j=0;j<n-i-1;j++){
                if(A[j]>A[j+1]){
                    swap(A[j],A[j+1]);
                    count++;
                }
            }
        }
        return count;
    }
};

C++中,实现数组的逆序可以通过多种方法,其中一种比较常见且简单的方式是使用头尾指针交换法。这种方法的基本思想是设置两个指针,一个指向数组的起始位置,另一个指向数组的结束位置。然后在这两个指针所指的元素之间进行交换,之后将两个指针向中间移动,直到它们相遇或者交错,这样整个数组的元素顺序就被逆序了。以下是具体的实现步骤: 1. 定义一个数组和相关的变量,包括起始指针和结束指针。 2. 在一个循环中,使用临时变量来交换起始指针和结束指针所指的元素。 3. 每次交换后,移动指针:起始指针向后移动一位,结束指针向前移动一位。 4. 当两个指针相遇或者交错时,循环结束。 示例代码如下: ```cpp #include <iostream> using namespace std; // 函数用于逆序数组 void reverseArray(int arr[], int size) { int start = 0; // 起始指针 int end = size - 1; // 结束指针 while (start < end) { // 交换元素 int temp = arr[start]; arr[start] = arr[end]; arr[end] = temp; // 移动指针 start++; end--; } } int main() { int arr[] = {1, 2, 3, 4, 5}; int size = sizeof(arr) / sizeof(arr[0]); reverseArray(arr, size); // 打印逆序后的数组 for (int i = 0; i < size; i++) { cout << arr[i] << " "; } cout << endl; return 0; } ``` 这段代码定义了一个`reverseArray`函数,它接受一个整数数组数组大小作为参数,并逆序数组中的元素。在`main`函数中创建了一个数组并调用了`reverseArray`函数,然后打印出了逆序后的数组
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

助力毕业

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值