zoukankan      html  css  js  c++  java
  • 二维码扫描&集合排序

    一、二维码扫描机制

    二维条码/二维码(2-dimensional bar code)是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的;在代码编制上巧妙地利用构成计算机内部逻辑基础的“0”、“1”比特流的概念,使用若干个与二进制相对应的几何形体来表示文字数值信息,通过图象输入设备或光电扫描设备自动识读以实现信息自动处理:它具有条码技术的一些共性:每种码制有其特定的字符集;每个字符占有一定的宽度;具有一定的校验功能等。同时还具有对不同行的信息自动识别功能、及处理图形旋转变化点。

    二维条码/二维码可以分为堆叠式/行排式二维条码和矩阵式二维条码。 堆叠式/行排式二维条码形态上是由多行短截的一维条码堆叠而成;矩阵式二维条码以矩阵的形式组成,在矩阵相应元素位置上用“点”表示二进制“1”, 用“空”表示二进制“0”,“点”和“空”的排列组成代码。



    二维码上面那三个大的正方形其实是一个定位的功能,从上到下依次表示的就是二进制数据,二维码具有一些容错率,所以有的二维码中间可以加头像、图片等,即可遮挡部分范围。一般我们也可以用一些在线生成二维码的网站,二维码其实就是一些字符串,所以我们可以在一些网站上面,直接输入一段文字或一个网站链接就自动生成一个二维码,例如我常用的草料二维码


    源码是ZXingCodeLibs,下载链接:zxingcode(二维码)

    二、集合排序

    ArrayListd的排序问题:

    public class Main {
    
    	public static void main(String[] args) {
    
    		ArrayList<Integer> list = new ArrayList<Integer>();
    
    		list.add(2);
    		list.add(1);
    		list.add(8);
    		list.add(3);
    		list.add(5);
    		list.add(4);
    
    		System.out.println("排序前:" + list);
    
    		Collections.sort(list, new Comparator<Integer>() {
    
    			@Override
    			public int compare(Integer lhs, Integer rhs) {
    				if (lhs < rhs) {
    					return 1;
    				} else {
    					return -1;
    				}
    			}
    		});
    
    		System.out.println("排序后:" + list);
    	}
    }
    



  • 相关阅读:
    ResNet & DenseNet
    82. 删除排序链表中的重复元素 II
    C++ Primer 笔记——多重继承与虚继承
    C++ Primer 笔记——命名空间
    C++ Primer 笔记——异常处理
    C++ Primer 笔记——模板与泛型编程
    C++ Primer 笔记——转发
    C++ Primer 笔记——理解std::move
    C++ Primer 笔记——OOP
    C++ Primer 笔记——重载运算
  • 原文地址:https://www.cnblogs.com/xiaowangba/p/6314908.html
Copyright © 2011-2022 走看看