计数器排序

计数器排序的时间复杂度是O(n),辅助空间为O(n),这个是典型的用空间换时间的方法。

下面的算法导论的经典接法:

package sort;

import java.util.Scanner;

public class CountSort {

	public static void main(String[] args) {
		Scanner reader = new Scanner(System.in);
		int a[] = new int[6];
		for (int i = 0; i <= 5; i++)
			a[i] = reader.nextInt();// 输入
		int b[] = new int[6];// 输出
		int num = 0;
		for (int i = 1; i <= 5; i++) {
			if (a[i] >= num)
				num = a[i];// 找数组a的最大值num
		}

		int c[] = new int[num + 1];// 创建num+1个辅助空间c[num+1]
		for (int i = 1; i <= num; i++) {// 给辅助空间c赋值为0
			c[i] = 0;

		}
		for (int j = 1; j <= 5; j++) {
			c[a[j]] = c[a[j]] + 1;// 找到a[j]在c[a[j]]中将c[a[j]]的值+1付给c[a[j]],其实就是记录a数组中的每个元素(就在c数组的对应位置)的重复个数

		}
		for (int i = 2; i <= num; i++) {
			c[i] = c[i] + c[i - 1];// 统计前面元素出现的总个数

		}
		for (int j = 5; j >= 1; j--) {
			b[c[a[j]]] = a[j];
			c[a[j]] = c[a[j]] - 1;

		}
		for (int i = 1; i <= 5; i++) {
			System.out.print(b[i] + " ");
		}

	}

}
下面是改进的算法:

package Sort;

import java.util.Scanner;

public class CountSort {

	public void SortC(int[] a, int length) {
		int num = 0;
		for (int i = 1; i <= 5; i++) {
			if (a[i] >= num)
				num = a[i];// 找数组a的最大值num
		}
		int[] c = new int[num + 1];
		for (int i = 0; i <= num; i++)
			c[i] = 0;
		for (int i = 0; i < length; i++) {
			int as = a[i];
			++c[as];

		}
		int index = 0;
		for (int i = 0; i <= num; ++i) {
			for (int j = 0; j < c[i]; ++j) {
				a[index] = i;
				++index;
			}

		}
		for (int i = 1; i <= 5; i++) {
			System.out.print(a[i] + " ");
		}

	}

	public static void main(String[] args) {
		Scanner reader = new Scanner(System.in);
		int a[] = new int[6];
		for (int i = 0; i <= 5; i++)
			a[i] = reader.nextInt();// 输入
		CountSort countSort = new CountSort();
		countSort.SortC(a, 6);

	}

}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python Redis计数器是一种用于记录特定事件或操作次数的工具。它可以在Redis数据库中存储计数器的信息,并通过执行相应的命令来更新计数器的值。 更新计数器信息的过程相对简单,程序只需要执行zadd命令和hincrby命令。其中,zadd命令用于按照指定的精度和时间片将计数器的值存储在有序集合中,hincrby命令用于递增计数器的值。 为了获取计数器的数据,可以使用hgetall命令从Redis中获取整个散列,并将返回的时间片和计数器的值转换为数字格式。然后,根据时间对数据进行排序,并返回排序后的数据。 以下是一个示例代码,用于从Redis中获取计数器数据并进行排序: ``` def get_counter(conn, name, precision): # 取得存储计数器数据的键的名字 hash = '%s:%s' % (precision, name) # 从Redis里面取出计数器数据 data = conn.hgetall('count:' + hash) to_return = [] # 将计数器数据转换成指定的格式 for key, value in data.iteritems(): to_return.append((int(key), int(value))) # 对数据进行排序,把旧的数据样本排在前面 to_return.sort() return to_return ``` 通过以上方法,可以方便地使用Python和Redis实现计数器功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Python--Redis实战:第五章:使用Redis构建支持程序:第2节:计数器和统计数据...](https://blog.csdn.net/weixin_34266504/article/details/88701536)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值