精华内容
下载资源
问答
  • SSH2框架搭建实例源码

    万次下载 热门讨论 2013-04-25 09:53:29
    SSH2框架搭建实例(spring3.2+strust2.3.4+hibernate4.2)全部采用最新版本.演示了用户登录和用户管理
  • Adaboost算法原理分析和实例+代码(简明易懂)

    万次阅读 多人点赞 2017-05-02 08:52:31
    Adaboost算法原理分析和实例+代码(简明易懂) 【尊重原创,转载请注明出处】 http://blog.csdn.net/guyuealian/article/details/70995333 本人最初了解AdaBoost算法着实是花了几天时间,才明白他的基本原理。...

    Adaboost算法原理分析和实例+代码(简明易懂)

       【尊重原创,转载请注明出处】 http://blog.csdn.net/guyuealian/article/details/70995333
        本人最初了解AdaBoost算法着实是花了几天时间,才明白他的基本原理。也许是自己能力有限吧,很多资料也是看得懵懵懂懂。网上找了一下关于Adaboost算法原理分析,大都是你复制我,我摘抄你,反正我也搞不清谁是原创。有些资料给出的Adaboost实例,要么是没有代码,要么省略很多步骤,让初学者很难看懂AdaBoost过程。
        本博客将会详细介绍AdaBoost算法过程,并给出了一个Adaboost例子的详细求解过程,当然也给出了Matlab代码求解过程。碍于太多复杂公式,文章是在电脑Word文档写好再复制上博客的,为了排版好看,有些地方给出了截图。
         下面给出几个我认为不错的博客资料:
    【1】http://blog.csdn.net/v_july_v/article/details/40718799 感谢这位博主给出了 Adaboost 算法的原理与推导,本文章很多地方都参考了他的内容
    【2】http://blog.csdn.net/m0_37407756/article/details/67637400 该博客有一个Adaboost 算法的例子,但其过程简略太多,初学者很难看懂。本文章的Adaboost 算法例子也是与之相对应的,但本人给出了详细的步骤和分析过程。话说,图都是我一个一个画上去,心疼我用了两天时间!!

    (1)鉴于很多网友评论留言说,为啥子第三次迭代时,“这个强分类器Hfinal对训练样本的错误率为0!”。这里要说明一下,如果你只是用眼去看,而不假思索一下,你是绝逼看不出结果来的!!!要计算,公式就是:{\color{Red} H_{final}=sign(f_{3}(x))}这个函数,其中是sign符号函数(大于0,返回1;小于0,则返回-1),把样本点X代入公式计算就可以得到预测结果了

    (2)为了照顾大家,我又重新绘制了表格,把每一步sign(f_{i}(x))的预测结果显示出来,详见每一次迭代的表格的sign(f_{i}(x))

    (3)附带了Matlab源代码,自己运行一下,就OK了

    (4)这份博客,花了我好大心血,记得点赞哈哈!

    (5)娃哈哈~!

    一、AdaBoost简介

          Boosting, 也称为增强学习或提升法,是一种重要的集成学习技术, 能够将预测精度仅比随机猜度略高的弱学习器增强为预测精度高的强学习器,这在直接构造强学习器非常困难的情况下,为学习算法的设计提供了一种有效的新思路和新方法。其中最为成功应用的是,Yoav Freund和Robert Schapire在1995年提出的AdaBoost算法。
          AdaBoost是英文"Adaptive Boosting"(自适应增强)的缩写,它的自适应在于:前一个基本分类器被错误分类的样本的权值会增大,而正确分类的样本的权值会减小,并再次用来训练下一个基本分类器。同时,在每一轮迭代中,加入一个新的弱分类器,直到达到某个预定的足够小的错误率或达到预先指定的最大迭代次数才确定最终的强分类器。
    Adaboost算法可以简述为三个步骤:
     (1)首先,是初始化训练数据的权值分布D1。假设有N个训练样本数据,则每一个训练样本最开始时,都被赋予相同的权值:w1=1/N。
     (2)然后,训练弱分类器hi。具体训练过程中是:如果某个训练样本点,被弱分类器hi准确地分类,那么在构造下一个训练集中,它对应的权值要减小;相反,如果某个训练样本点被错误分类,那么它的权值就应该增大。权值更新过的样本集被用于训练下一个分类器,整个训练过程如此迭代地进行下去。
     (3)最后,将各个训练得到的弱分类器组合成一个强分类器。各个弱分类器的训练过程结束后,加大分类误差率小的弱分类器的权重,使其在最终的分类函数中起着较大的决定作用,而降低分类误差率大的弱分类器的权重,使其在最终的分类函数中起着较小的决定作用。
      换而言之,误差率低的弱分类器在最终分类器中占的权重较大,否则较小。

    二、AdaBoost算法过程

        给定训练数据集:,其中用于表示训练样本的类别标签,i=1,...,N。Adaboost的目的就是从训练数据中学习一系列弱分类器或基本分类器,然后将这些弱分类器组合成一个强分类器。

    相关符号定义:

    Adaboost的算法流程如下:

    相关说明:

    综合上面的推导,可得样本分错与分对时,其权值更新的公式为:

    1、鉴于很多网友反应,归一化常数Z_t是怎么来的,这个我就不做推导,直接给个截图吧:

    截图来自:https://blog.csdn.net/m0_37407756/article/details/67637400

    三、AdaBoost实例讲解

     例:给定如图所示的训练样本,弱分类器采用平行于坐标轴的直线用Adaboost算法的实现强分类过程。


    数据分析:

       将这10个样本作为训练数据,根据 X 和Y 的对应关系,可把这10个数据分为两类,图中用“+”表示类别1,用“O”表示类别-1。本例使用水平或者垂直的直线作为分类器,图中已经给出了三个弱分类器,即:

    初始化:

       首先需要初始化训练样本数据的权值分布,每一个训练样本最开始时都被赋予相同的权值:wi=1/N,这样训练样本集的初始权值分布D1(i):

       令每个权值w1i = 1/N = 0.1,其中,N = 10,i = 1,2, ..., 10,然后分别对于t= 1,2,3, ...等值进行迭代(t表示迭代次数,表示第t轮),下表已经给出训练样本的权值分布情况:

    第1次迭代t=1:

      初试的权值分布D1为1/N(10个数据,每个数据的权值皆初始化为0.1),

                                                           D1=[0.1,  0.1, 0.1, 0.1, 0.1, 0.1,0.1, 0.1, 0.1, 0.1]

      在权值分布D1的情况下,取已知的三个弱分类器h1、h2和h3中误差率最小的分类器作为第1个基本分类器H1(x)(三个弱分类器的误差率都是0.3,那就取第1个吧)

        在分类器H1(x)=h1情况下,样本点“5 7 8”被错分,因此基本分类器H1(x)的误差率为:

      可见,被误分类样本的权值之和影响误差率e,误差率e影响基本分类器在最终分类器中所占的权重α

      然后,更新训练样本数据的权值分布,用于下一轮迭代,对于正确分类的训练样本“1 2 3 4 6 9 10”(共7个)的权值更新为:

     这样,第1轮迭代后,最后得到各个样本数据新的权值分布:

    D2=[1/14,1/14,1/14,1/14,1/6,1/14,1/6,1/6,1/14,1/14]

      由于样本数据“5 7 8”被H1(x)分错了,所以它们的权值由之前的0.1增大到1/6;反之,其它数据皆被分正确,所以它们的权值皆由之前的0.1减小到1/14,下表给出了权值分布的变换情况:

        可得分类函数:f1(x)= α1H1(x) = 0.4236H1(x)。此时,组合一个基本分类器sign(f1(x))作为强分类器在训练数据集上有3个误分类点(即5 7 8),此时强分类器的训练错误为:0.3

    第二次迭代t=2:

      在权值分布D2的情况下,再取三个弱分类器h1、h2和h3中误差率最小的分类器作为第2个基本分类器H2(x):
    ① 当取弱分类器h1=X1=2.5时,此时被错分的样本点为“5 7 8”:
    误差率e=1/6+1/6+1/6=3/6=1/2;
    ② 当取弱分类器h2=X1=8.5时,此时被错分的样本点为“3 4 6”:
    误差率e=1/14+1/14+1/14=3/14;
    ③ 当取弱分类器h3=X2=6.5时,此时被错分的样本点为“1 2 9”:
    误差率e=1/14+1/14+1/14=3/14;

          

         因此,取当前最小的分类器h2作为第2个基本分类器H2(x)

                                                              

        显然,H2(x)把样本“3 4 6”分错了,根据D2可知它们的权值为D2(3)=1/14,D2(4)=1/14, D2(6)=1/14,所以H2(x)在训练数据集上的误差率:

      这样,第2轮迭代后,最后得到各个样本数据新的权值分布:

                                               D3=[1/22,1/22,1/6,1/6,7/66,1/6,7/66,7/66,1/22,1/22]

      下表给出了权值分布的变换情况:

       可得分类函数:f2(x)=0.4236H1(x) + 0.6496H2(x)。此时,组合两个基本分类器sign(f2(x))作为强分类器在训练数据集上有3个误分类点(即3 4 6),此时强分类器的训练错误为:0.3

    第三次迭代t=3:

      在权值分布D3的情况下,再取三个弱分类器h1、h2和h3中误差率最小的分类器作为第3个基本分类器H3(x):
    ① 当取弱分类器h1=X1=2.5时,此时被错分的样本点为“5 7 8”:
    误差率e=7/66+7/66+7/66=7/22;
    ② 当取弱分类器h2=X1=8.5时,此时被错分的样本点为“3 4 6”:
    误差率e=1/6+1/6+1/6=1/2=0.5;
    ③ 当取弱分类器h3=X2=6.5时,此时被错分的样本点为“1 2 9”:
    误差率e=1/22+1/22+1/22=3/22;

       

       因此,取当前最小的分类器h3作为第3个基本分类器H3(x):

      这样,第3轮迭代后,得到各个样本数据新的权值分布为:

                                                     D4=[1/6,1/6,11/114,11/114,7/114,11/114,7/114,7/114,1/6,1/38]

      下表给出了权值分布的变换情况:

        可得分类函数:f3(x)=0.4236H1(x) + 0.6496H2(x)+0.9229H3(x)。此时,组合三个基本分类器sign(f3(x))作为强分类器,在训练数据集上有0个误分类点。至此,整个训练过程结束。

      整合所有分类器,可得最终的强分类器为:

        这个强分类器Hfinal对训练样本的错误率为0!

        本例Matlab代码,如下:

        先建立Matlab函数文件,定义h1,h2和h3三个弱分类器

    function kind = wcH1( X,TH )
    %h1弱分类器
    X1=X(1);
    X2=X(2);
    if X1<TH
        kind=1;
    else
        kind=-1;
    end
    end
    
    function kind = wcH2( X,TH )
    %h2弱分类器
    X1=X(1);
    X2=X(2);
    if X1<TH
        kind=1;
    else
        kind=-1;
    end
    end
    function kind = wcH3( X,TH )
    %h3弱分类器
    X1=X(1);
    X2=X(2);
    if X2<TH
        kind=-1;
    else
        kind=1;
    end
    end
    

       主程序Matlab代码:

    clc,clear all;
    %% 训练样本数据
     xData=[1 5;2 2;3 1;4 6;6 8;6 5;7 9;8 7;9 8;10 2] %样本数据点,对应编号为1,2,...10
     Y=[1 1 -1 -1 1 -1 1 1 -1 -1]';                             %对应的样本类别,用1和-1表示
     xNum=1:10;                                                      %编号
     format rat
     %% 绘制样本分布图
     L1=find(Y==1);
     x=xData(L1,1);y=xData(L1,2);
    plot(x,y,'b+','LineWidth',3,'MarkerSize',12);
    hold on;
     L2=find(Y==-1);
    x=xData(L2,1);y=xData(L2,2);
    plot(x,y,'ro','LineWidth',3,'MarkerSize',12);
    xlabel('X1');ylabel('X2');axis([0 10 0 10])
    %% ***********************************初试过程************************************
    H1=zeros(10,1);H2=H1;H3=H1
    for i=1:10
        X=xData(i,:);
        H1(i) = wcH1( X,2.5 );%弱分类器h1
        H2(i) = wcH2( X,8.5 );%弱分类器h2
        H3(i) = wcH3( X,6.5 );%弱分类器h3
    end
    errDataH1=find(H1~=Y);%找到被h1错分的样本点的序号
    errDataH2=find(H2~=Y);%找到被h2错分的样本点的序号
    errDataH3=find(H3~=Y);%找到被h3错分的样本点的序号
    accDataH1=find(H1==Y);%找到被h1正确分的样本点的序号
    accDataH2=find(H2==Y);%找到被h2正确分的样本点的序号
    accDataH3=find(H3==Y);%找到被h3正确分的样本点的序号
    errDataAll=[errDataH1,errDataH2,errDataH3];
    accDataAll=[accDataH1,accDataH2,accDataH3];
    
    N=10;
    D1=zeros(10,1)+1/N       % 初始化权值分布
    %% ***********************************第一次迭代***********************************
    err1=sum(D1(errDataH1,:));%所有被错分类的样本点的权值之和即为误差率
    err2=sum(D1(errDataH2,:));%所有被错分类的样本点的权值之和即为误差率
    err3=sum(D1(errDataH3,:));%所有被错分类的样本点的权值之和即为误差率
    errAll=[err1,err2,err3];
    [minErr,minIndex]=min(errAll);
    %根据误差率e1计算H1的系数:
    a1=0.5*log((1-minErr)/minErr)
    minErrData=errDataAll(:,minIndex);
    minAccData=accDataAll(:,minIndex);
    D2=D1;
    for i=minAccData'
        D2(i)=D2(i)/(2*(1-minErr));
    end
    for i=minErrData'
         D2(i)=D2(i)/(2*minErr);
    end
    D2
    %分类函数
    f1=a1.*H1;
    kindFinal=sign(f1)%此时强分类器的分类结果
    
    %% ***********************************第二次迭代***********************************
    err1=sum(D2(errDataH1,:));%所有被错分类的样本点的权值之和即为误差率
    err2=sum(D2(errDataH2,:));%所有被错分类的样本点的权值之和即为误差率
    err3=sum(D2(errDataH3,:));%所有被错分类的样本点的权值之和即为误差率
    errAll=[err1,err2,err3];
    [minErr,minIndex]=min(errAll);
    % 根据误差率e2计算H2的系数:
    a2=0.5*log((1-minErr)/minErr)
    minErrData=errDataAll(:,minIndex);
    minAccData=accDataAll(:,minIndex);
    D3=D2;
    for i=minAccData'
        D3(i)=D3(i)/(2*(1-minErr));
    end
    for i=minErrData'
         D3(i)=D3(i)/(2*minErr);
    end
    D3
    % 分类函数
    f2=a1.*H1+a2*H2;
    kindFinal=sign(f2)%此时强分类器的分类结果
    
    %% ***********************************第三次迭代***********************************
    err1=sum(D3(errDataH1,:));%所有被错分类的样本点的权值之和即为误差率
    err2=sum(D3(errDataH2,:));%所有被错分类的样本点的权值之和即为误差率
    err3=sum(D3(errDataH3,:));%所有被错分类的样本点的权值之和即为误差率
    errAll=[err1,err2,err3];
    [minErr,minIndex]=min(errAll);
    % 根据误差率e3计算G3的系数:
    a3=0.5*log((1-minErr)/minErr)
    minErrData=errDataAll(:,minIndex);
    minAccData=accDataAll(:,minIndex);
    D4=D3;
    for i=minAccData'
        D4(i)=D4(i)/(2*(1-minErr));
    end
    for i=minErrData'
         D4(i)=D4(i)/(2*minErr);
    end
    D4
    % 分类函数
    f3=a1.*H1+a2*H2+a3*H3;
    kindFinal=sign(f3)%此时强分类器的分类结果
    %%

        Adaboost算法的某些特性是非常好的,这里主要介绍Adaboost的两个特性。(1)是训练的错误率上界,随着迭代次数的增加,会逐渐下降;(2)Adaboost算法即使训练次数很多,也不会出现过拟合的问题。关于这两方面的研究和分析,我建议各大网友,还是看看大神的博客:http://blog.csdn.net/v_july_v/article/details/40718799

    四、AdaBoost的优点和缺点

    优点

         (1)Adaboost提供一种框架,在框架内可以使用各种方法构建子分类器。可以使用简单的弱分类器,不用对特征进行筛选。

         (2)Adaboost算法不需要弱分类器的先验知识,最后得到的强分类器的分类精度依赖于所有弱分类器。无论是应用于人造数据还是真实数据,Adaboost都能显著的提高学习精度。

         (3)Adaboost算法不需要预先知道弱分类器的错误率上限,且最后得到的强分类器的分类精度依赖于所有弱分类器的分类精度,可以深挖分类器的能力。Adaboost可以根据弱分类器的反馈,自适应地调整假定的错误率,执行的效率高。

         (4)Adaboost对同一个训练样本集训练不同的弱分类器,按照一定的方法把这些弱分类器集合起来,构造一个分类能力很强的强分类器,即“三个臭皮匠赛过一个诸葛亮”。

    缺点:

         在Adaboost训练过程中,Adaboost会使得难于分类样本的权值呈指数增长,训练将会过于偏向这类困难的样本,导致Adaboost算法易受噪声干扰。此外,Adaboost依赖于弱分类器,而弱分类器的训练时间往往很长。

    如果你觉得该帖子帮到你,还望贵人多多支持,鄙人会再接再厉,继续努力的~

    展开全文
  • 基于google Zxing实现二维码、条形码扫描,仿微信二维码扫描效果,这里是实例代码下载 ,项目详情http://blog.csdn.net/xiaanming/article/details/10163203 了解二维码这个东西还是从微信中,当时微信推出二维码扫描...
  • centos7 MySQL5.7 多实例安装教程

    万次阅读 2020-12-25 18:03:45
    各个实例之间是相互独立的,每个实例的datadir, port, socket, pid都是不同的。 2、多实例特点 2.1 有效利用服务器资源,当单个服务器资源有剩余时,可以充分利用剩余的资源提供更多的服务。 2.2 资源互相抢占问题,...

    1、背景

    今天,有个朋友问我,一台服务器上面能不能安装多个MySQL呢?这样我们就可以用不同的代码使用不同的数据库了。我知道肯定是可以的,但是按照以前编译安装的方式好像很麻烦,又重新整理了一版其他安装方式的多实例安装文档,特来记录。但是线上需不需要这个东西,还是要看业务需求。此文当做学习笔记记录操作过程,希望可以帮助其他的朋友。
    介绍:MySQL数据库的集中化运维,可以通过在一台服务器上,部署运行多个MySQL服务进程,通过不同的socket监听不同的服务端口来提供各自的服务。各个实例之间是相互独立的,每个实例的datadir, port, socket, pid都是不同的。

    2、多实例特点

    2.1 有效利用服务器资源,当单个服务器资源有剩余时,可以充分利用剩余的资源提供更多的服务。
    2.2 资源互相抢占问题,当某个服务实例服务并发很高时或者开启慢查询时,会消耗更多的内存、CPU、磁盘IO资源,导致服务器上的其他实例提供服务的质量下降。

    3、环境

    必须关闭selinux

    [root@node2 local]# cat /etc/redhat-release 
    CentOS Linux release 7.4.1708 (Core) 
    [root@node2 local]# uname  -r
    3.10.0-1160.11.1.el7.x86_64
    [root@MySQL ~]# getenforce 
    Disabled
    

    4、部署 [ 4个实例 ]

    4.1 下载 MySQL 5.7 二制包 [ 推荐官方下载 ] 此下载版本大于5.7.5

    [root@node2  ~]# wget wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz
    

    4.2 解压 MySQL 5.7 二进制包到指定目录

    [root@node2  ~]# tar zxvf mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz -C /usr/local/
    

    4.3 创建 MySQL 软链接

    [root@node2 ~]# mv /usr/local/mysql-5.7.18-linux-glibc2.5-x86_64 /usr/local/mysql
    

    4.4 创建 MySQL 用户

    [root@node2 ~]# useradd -r -s /sbin/nologin mysql
    

    4.5 在 MySQL 二进制包目录中创建 mysql-files 目录 [MySQL 数据导入/导出数据专放目录]

    [root@node2 ~]# mkdir -v /usr/local/mysql/mysql-files
    mkdir: created directory `/usr/local/mysql/mysql-files'
    

    4.6 创建多实例数据目录

    [root@node2 local]# mkdir -vp /data/mysql/data{3306..3309}
    mkdir: 已创建目录 "/data/mysql"
    mkdir: 已创建目录 "/data/mysql/data3306"
    mkdir: 已创建目录 "/data/mysql/data3307"
    mkdir: 已创建目录 "/data/mysql/data3308"
    mkdir: 已创建目录 "/data/mysql/data3309"
    

    4.7 修改 MySQL 二进制包目录的所属用户与所属组

    [root@node2 local]# chown mysql.mysql /usr/local/mysql/ -R
    [root@node2 local]# chown mysql.mysql /data/mysql -R
    

    4.8 配置 MySQL 配置文件 /etc/my.cnf

    [mysqld_multi]
    mysqld    = /usr/local/mysql/bin/mysqld 
    mysqladmin = /usr/local/mysql/bin/mysqladmin
    log        = /tmp/mysql_multi.log
     
    [mysqld3306]
    datadir = /data/mysql/data3306  # 设置数据目录 [多实例中一定要不同]
    socket = /tmp/mysql-3306.sock  # 设置sock存放文件名 [多实例中一定要不同]
    port = 3306    # 设置监听开放端口 [多实例中一定要不同]
    user = mysql  # 设置运行用户
    innodb_buffer_pool_size = 32M  # 设置innodb 缓存大小
    sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
    
    [mysqld3307]
    datadir = /data/mysql/data3307
    socket = /tmp/mysql-3307.sock
    port = 3307
    user = mysql
    innodb_buffer_pool_size = 32M
    sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
    
    [mysqld3308]
    datadir = /data/mysql/data3308
    socket = /tmp/mysql-3308.sock
    port = 3308
    user = mysql
    innodb_buffer_pool_size = 32M
    sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
    
    [mysqld3309]
    datadir = /data/mysql/data3309
    socket = /tmp/mysql-3309.sock
    port = 3309
    user = mysql
    innodb_buffer_pool_size = 32M
    sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
    

    4.9 初始化各个实例 [ 初始化完成后会自带随机密码在输出日志中 ]

    [root@node2 ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3306
    [root@node2 ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3307
    [root@node2 ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3308
    [root@node2 ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3309
    

    注意:初始化的时候会输出密码,记录下来:2020-12-25T06:39:00.288011Z 1 [Note] A temporary password is generated for root@localhost: dfIx98z,3fj(

    4.10 各实例开启 SSL 连接

    [root@node2 ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3306
    [root@node2 ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3307
    [root@node2  ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3308
    [root@node2  ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data3309
    
    • 复制多实例脚本到服务管理目录下 [ /etc/init.d/ ]
    [root@node2 ~]# cp /usr/local/mysql/support-files/mysqld_multi.server /etc/init.d/mysqld_multi
    

    4.11 添加脚本执行权限

    [root@node2 ~]# chmod +x /etc/init.d/mysqld_multi 
    

    4.12 添加进service服务管理和配置环境变量

    [root@node2 ~]# chkconfig --add mysqld_multi
    [root@node2 ~]# echo "export PATH=$PATH:/usr/local/mysql/bin" >>/etc/profile
    [root@node2 ~]# source /etc/profile
    

    4.13 启动多实例

    [root@node2 local]#  /usr/local/mysql/bin/mysqld_multi start    #开启多实例
    [root@node2 local]#  /usr/local/mysql/bin/mysqld_multi report   #查看全部实例状态
    [root@node2 local]#  /usr/local/mysql/bin/mysqld_multi start 3306 #启动单个实例
    [root@node2 local]#  /usr/local/mysql/bin/mysqld_multi stop  3306 #停止单个实例
    [root@node2 local]#  /usr/local/mysql/bin/mysqld_multi report
    Reporting MySQL servers
    MySQL server from group: mysqld3306 is running
    MySQL server from group: mysqld3307 is running
    MySQL server from group: mysqld3308 is running
    MySQL server from group: mysqld3309 is running
    

    4.14 查看实例监听端口

    [root@node2 local]#  netstat -lntp | grep mysqld
    tcp6       0      0 :::3306                 :::*                    LISTEN      8898/mysqld         
    tcp6       0      0 :::3307                 :::*                    LISTEN      8901/mysqld         
    tcp6       0      0 :::3308                 :::*                    LISTEN      8904/mysqld         
    tcp6       0      0 :::3309                 :::*                    LISTEN      8907/mysqld   
    

    5. 连接测试

    实例3306测试:

    [root@node2 local]# mysql -uroot -p -S /tmp/mysql-3306.sock 
    Enter password:  #输入4.9 初始化输出的密码
    Server version: 5.7.18 MySQL Community Server (GPL)
    ..................
    mysql> set password for root@'localhost'=password('123456'); 
    mysql> flush privileges;
    mysql> create database test  ; #可以看到该实例的data目录下多了一个test库
    

    其他实例连接:

    [root@node2 local]# mysql -uroot -p -S /tmp/mysql-3307.sock  
    [root@node2 local]# mysql -uroot -p -S /tmp/mysql-3308.sock  
    [root@node2 local]# mysql -uroot -p -S /tmp/mysql-3309.sock  
    

    遇到的问题:
    /usr/local/mysql/bin/mysqld_multi stop 3306 停止3306实例无效。
    解决: 自己写一个脚本来实现启停功能
    #先把密码存放到一个安全的文件里面

    echo '123456' >  /etc/mysql.pass
    chmod 600   /etc/mysql.pass
    vim /etc/init.d/mysqld_manager  #以后就可以通过这个脚本来管理mysql了
    #!/bin/bash
    tag=$1
    port=$2
    mysqld_multi="/usr/local/mysql/bin/mysqld_multi"
    sql="/usr/local/mysql/bin/mysql"
    sqladmin="/usr/local/mysql/bin/mysqladmin"
    if [ "$tag" == "start" ] && [ "$port" == '' ];then 
        $mysqld_multi start 
    else   
        case "$tag" in
            'start' )
                $mysqld_multi start $port
                ;;
            'stop' )
                $sqladmin -uroot -p`cat /etc/mysql.pass` -S /tmp/mysql-$port.sock  shutdown
                ;;
            'report' )
                $mysqld_multi report $port
                ;;
            'restart' )
                $sqladmin -uroot -p`cat /etc/mysql.pass` -S /tmp/mysql-$port.sock  shutdown
                $mysqld_multi start $port
                ;;
            *)
                echo "Usage: $0 {start|stop|report|restart}" >&2
                ;;
        esac
    fi    
    #赋权
    chmod 755  /etc/init.d/mysqld_manager 
    
    展开全文
  • C++编程实例100篇

    千次下载 热门讨论 2013-08-28 10:48:45
    C++编程实例100篇,里面有很多很基础的编程实例,可以作为参考。
  • uml实例uml实例uml实例uml实例uml实例

    热门讨论 2009-06-22 17:48:02
    uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例uml实例
  • SpringMVC实例

    千次下载 热门讨论 2012-07-22 16:46:30
    Spring MVC小实例
  • 如何在IDEA启动多个Spring Boot工程实例

    万次阅读 多人点赞 2017-07-30 22:27:01
    在我讲解的案例中,经常一个工程启动多个实例,分别占用不同的端口,有很多读者百思不得其解,在博客上留言,给我发邮件,加我微信询问。所以有必要在博客上记录下,方便读者。step 1在IDEA上点击Application右边的...

    转载请标明出处:
    https://blog.csdn.net/forezp/article/details/76408139
    本文出自方志朋的博客

    个人博客纯净版:https://www.fangzhipeng.com/architecture/2017/08/10/idea-boot-instances.html

    在我讲解的案例中,经常一个工程启动多个实例,分别占用不同的端口,有很多读者百思不得其解,在博客上留言,给我发邮件,加我微信询问。所以有必要在博客上记录下,方便读者。

    step 1

    在IDEA上点击Application右边的下三角
    ,弹出选项后,点击Edit Configuration

    在这里插入图片描述

    step 2

    打开配置后,将默认的Single instance only(单实例)的钩去掉。
    在这里插入图片描述

    step 3

    通过修改application文件的server.port的端口,启动。多个实例,需要多个端口,分别启动。

    更多阅读

    史上最简单的 SpringCloud 教程汇总

    SpringBoot教程汇总

    Java面试题系列汇总


    扫码关注公众号有惊喜

    (转载本站文章请注明作者和出处 方志朋的博客

    展开全文
  • js图片轮播:VCD包装盒个性幻灯片实例源码

    万次下载 热门讨论 2014-06-15 19:04:08
    代码为博客实例代码:http://blog.csdn.net/lmj623565791/article/details/31015121 有问题博客中留言
  • Spring和ActiveMQ的整合实例源码

    千次下载 热门讨论 2015-09-26 15:37:45
    实例基于Spring+JMS+ActiveMQ+Tomcat,注解的完整实例,包含jar包
  • java源码包---java 源码 大量 实例

    千次下载 热门讨论 2013-04-18 23:15:26
     Java波浪文字,一个利用Java处理字符的实例,可以设置运动方向参数,显示文本的字符数组,高速文本颜色,显示字体的 FontMetrics对象,得到Graphics实例,得到Image实例,填充颜色数组数据,初始化颜色数组。...
  • 198个经典C#WinForm实例源码 超赞的完整版

    千次下载 热门讨论 2013-07-14 18:27:44
    "198个经典C#WinForm实例源码"包括: 1-窗体技巧 2-控件操作 3-图像操作 4-报表打印 5-系统操作 6-文件处理 7-网络操作 8-数据库操作 9-加密解密 10-硬件读写 11-游戏设计 "超赞的198个经典C#WinForm实例源码.zip " ...
  • Android 超高仿 QQ5.0 侧滑菜单项目完整实例代码

    万次下载 热门讨论 2014-09-14 01:12:27
    代码为博客的实例代码,有问题请博客中留言:http://blog.csdn.net/lmj623565791/article/details/39185641
  • Openlayers实例详解

    千人学习 2019-08-09 14:33:56
    本课程选取了OpenLayers一些具有典型代表性的实例进行详解。讲解实例过程中对涉及到的相关知识点进行穿插分析介绍,适合初学者对OpenLayers形成整体认识、树立学习信心。 课程涉及到map、view、projection、layer、...
  • vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全vf实例大全
  • RecyclerView 瀑布流、ListView、GridView实例源码

    万次下载 热门讨论 2015-04-15 20:21:26
    代码为博客实例代码,http://blog.csdn.net/lmj623565791/article/details/45059587 有问题请博客留言
  • vc界面编程经典实例

    千次下载 热门讨论 2013-03-28 10:45:23
    常用的vc界面编程经典实例,包含上百个实例的整理文档。常用的vc界面编程经典实例,包含上百个实例的整理文档。常用的vc界面编程经典实例,包含上百个实例的整理文档。常用的vc界面编程经典实例,包含上百个实例的...
  • 例子主要包括SocketAsyncEventArgs通讯封装、服务端实现日志查看、SCOKET列表、上传、下载、远程文件流、吞吐量协议,用于测试SocketAsyncEventArgs的性能和压力,最大连接数支持65535个长连接,最高命令交互速度...
  • ssh2实例ssh2实例

    热门讨论 2011-11-17 23:30:14
    ssh2实例ssh2实例ssh2实例ssh2实例
  • 实例002:“个税计算” 实例003:完全平方数 实例004:这天第几天 实例005:三数排序 实例006:斐波那契数列 实例007:copy 实例008:九九乘法表 实例009:暂停一秒输出 实例010:给人看的时间 实例011:养兔子 实例...

    Python3 100例

    原题地址:
    http://www.runoob.com/python/python-100-examples.html
    git地址:
    https://github.com/RichardFu123/Python100Cases
    转载请标注:
    https://blog.csdn.net/weixin_41084236/article/details/81564963
    原例为Python2.7版本
    重写过程中有不少是随意发挥的
    重写运行版本:Python3.7
    作者:Shawn

    • 总的来说,并没有什么难度,全部搂了一遍也只花了不到2天时间,其中还有一半以上的时间是用来写文档的。
    • 用来练练手还是凑合的。

    文章目录

    实例001:数字组合

    题目 有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?

    程序分析 遍历全部可能,把有重复的剃掉。

    total=0
    for i in range(1,5):
        for j in range(1,5):
            for k in range(1,5):
                if ((i!=j)and(j!=k)and(k!=i)):
                    print(i,j,k)
                    total+=1
    print(total)
    

    简便方法 用itertools中的permutations即可。

    import itertools
    sum2=0
    a=[1,2,3,4]
    for i in itertools.permutations(a,3):
        print(i)
        sum2+=1
    print(sum2)
    
    

    实例002:“个税计算”

    题目 企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?

    程序分析 分区间计算即可。

    profit=int(input('Show me the money: '))
    bonus=0
    thresholds=[100000,100000,200000,200000,400000]
    rates=[0.1,0.075,0.05,0.03,0.015,0.01]
    for i in range(len(thresholds)):
        if profit<=thresholds[i]:
            bonus+=profit*rates[i]
            profit=0
            break
        else:
            bonus+=thresholds[i]*rates[i]
            profit-=thresholds[i]
    bonus+=profit*rates[-1]
    print(bonus)
    

    实例003:完全平方数

    题目 一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

    程序分析 因为168对于指数爆炸来说实在太小了,所以可以直接省略数学分析,用最朴素的方法来获取上限:

    n=0
    while (n+1)**2-n*n<=168:
        n+=1
    
    print(n+1)
    ----------
    
    85
    
    

    思路是:最坏的结果是n的平方与(n+1)的平方刚好差168,由于是平方的关系,不可能存在比这更大的间隙。
    至于判断是否是完全平方数,最简单的方法是:平方根的值小数为0即可。
    结合起来:

    n=0
    while (n+1)**2-n*n<=168:
        n+=1
    
    for i in range((n+1)**2):
        if i**0.5==int(i**0.5) and (i+168)**0.5==int((i+168)**0.5):
            print(i-100)
    

    实例004:这天第几天

    题目 输入某年某月某日,判断这一天是这一年的第几天?

    程序分析 特殊情况,闰年时需考虑二月多加一天:

    def isLeapYear(y):
        return (y%400==0 or (y%4==0 and y%100!=0))
    DofM=[0,31,28,31,30,31,30,31,31,30,31,30]
    res=0
    year=int(input('Year:'))
    month=int(input('Month:'))
    day=int(input('day:'))
    if isLeapYear(year):
        DofM[2]+=1
    for i in range(month):
        res+=DofM[i]
    print(res+day)
    
    

    实例005:三数排序

    题目 输入三个整数x,y,z,请把这三个数由小到大输出。

    程序分析 练练手就随便找个排序算法实现一下,偷懒就直接调函数。

    raw=[]
    for i in range(3):
        x=int(input('int%d: '%(i)))
        raw.append(x)
        
    for i in range(len(raw)):
        for j in range(i,len(raw)):
            if raw[i]>raw[j]:
                raw[i],raw[j]=raw[j],raw[i]
    print(raw)
    
    
    raw2=[]
    for i in range(3):
        x=int(input('int%d: '%(i)))
        raw2.append(x)
    print(sorted(raw2))
    
    

    实例006:斐波那契数列

    题目 斐波那契数列。

    程序分析 斐波那契数列(Fibonacci sequence),从1,1开始,后面每一项等于前面两项之和。图方便就递归实现,图性能就用循环。

    # 递归实现
    def Fib(n):
        return 1 if n<=2 else Fib(n-1)+Fib(n-2)
    print(Fib(int(input())))
        
    # 朴素实现
    target=int(input())
    res=0
    a,b=1,1
    for i in range(target-1):
        a,b=b,a+b
    print(a)
    
    

    实例007:copy

    题目 将一个列表的数据复制到另一个列表中。

    程序分析 使用列表[:],拿不准可以调用copy模块。

    import copy
    a = [1,2,3,4,['a','b']]
    
    b = a					# 赋值
    c = a[:]				# 浅拷贝
    d = copy.copy(a)		# 浅拷贝
    e = copy.deepcopy(a)	# 深拷贝
    
    a.append(5)
    a[4].append('c')
    
    print('a=',a)
    print('b=',b)
    print('c=',c)
    print('d=',d)
    print('e=',e)
    
    ============ RESTART: F:\PyWorkspace\Python100\100examples\007.py ============
    a= [1, 2, 3, 4, ['a', 'b', 'c'], 5]
    b= [1, 2, 3, 4, ['a', 'b', 'c'], 5]
    c= [1, 2, 3, 4, ['a', 'b', 'c']]
    d= [1, 2, 3, 4, ['a', 'b', 'c']]
    e= [1, 2, 3, 4, ['a', 'b']]
    

    实例008:九九乘法表

    题目 输出 9*9 乘法口诀表。

    程序分析 分行与列考虑,共9行9列,i控制行,j控制列。

    for i in range(1,10):
        for j in range(1,i+1):
            print('%d*%d=%2ld '%(i,j,i*j),end='')
        print()
    

    实例009:暂停一秒输出

    题目 暂停一秒输出。

    程序分析 使用 time 模块的 sleep() 函数。

    import time
    for i in range(4):
        print(str(int(time.time()))[-2:])
        time.sleep(1)
    

    实例010:给人看的时间

    题目 暂停一秒输出,并格式化当前时间。

    程序分析 同009.

    import time
    
    for i in range(4):
        print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())))
        time.sleep(1)
    

    实例011:养兔子

    题目 有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

    程序分析 我认为原文的解法有点扯,没有考虑3个月成熟的问题,人家还是婴儿怎么生孩子?考虑到三个月成熟,可以构建四个数据,其中:一月兔每个月长大成为二月兔,二月兔变三月兔,三月兔变成年兔,成年兔(包括新成熟的三月兔)生等量的一月兔。

    month=int(input('繁殖几个月?: '))
    month_1=1
    month_2=0
    month_3=0
    month_elder=0
    for i in range(month):
        month_1,month_2,month_3,month_elder=month_elder+month_3,month_1,month_2,month_elder+month_3
        print('第%d个月共'%(i+1),month_1+month_2+month_3+month_elder,'对兔子')
        print('其中1月兔:',month_1)
        print('其中2月兔:',month_2)
        print('其中3月兔:',month_3)
        print('其中成年兔:',month_elder)
    

    实例012:100到200的素数

    题目 判断101-200之间有多少个素数,并输出所有素数。

    程序分析 判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。 用else可以进一步简化代码.

    import math
    for i in range(100,200):
        flag=0
        for j in range(2,round(math.sqrt(i))+1):
            if i%j==0:
                flag=1
                break
        if flag:
            continue
        print(i)
    
    
    print('\nSimplify the code with "else"\n')
    
    
    for i in range(100,200):
        for j in range(2,round(math.sqrt(i))+1):
            if i%j==0:
                break
        else:
            print(i)
    

    实例013:所有水仙花数

    题目 打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。

    程序分析 利用for循环控制100-999个数,每个数分解出个位,十位,百位。

    for i in range(100,1000):
        s=str(i)
        one=int(s[-1])
        ten=int(s[-2])
        hun=int(s[-3])
        if i == one**3+ten**3+hun**3:
            print(i)
    

    实例014:分解质因数

    题目 将一个整数分解质因数。例如:输入90,打印出90=233*5。

    程序分析 根本不需要判断是否是质数,从2开始向数本身遍历,能整除的肯定是最小的质数。

    target=int(input('输入一个整数:'))
    print(target,'= ',end='')
    
    if target<0:
        target=abs(target)
        print('-1*',end='')
    
    flag=0
    if target<=1:
        print(target)
        flag=1
    
    
    while True:
        if flag:
            break
        for i in range(2,int(target+1)):
            if target%i==0:
                print("%d"%i,end='')
                if target==i:
                    flag=1
                    break
                print('*',end='')
                target/=i
                break
            
    

    实例015:分数归档

    题目 利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。

    程序分析 用条件判断即可。

    points=int(input('输入分数:'))
    if points>=90:
        grade='A'
    elif points<60:
        grade='C'
    else:
        grade='B'
    print(grade)
    

    实例016:输出日期

    题目 输出指定格式的日期。

    程序分析 使用 datetime 模块。

    import datetime
    print(datetime.date.today())
    print(datetime.date(2333,2,3))
    print(datetime.date.today().strftime('%d/%m/%Y'))
    day=datetime.date(1111,2,3)
    day=day.replace(year=day.year+22)
    print(day)
    

    实例017:字符串构成

    题目 输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

    程序分析 利用 while 或 for 语句,条件为输入的字符不为 ‘\n’。

    string=input("输入字符串:")
    alp=0
    num=0
    spa=0
    oth=0
    for i in range(len(string)):
        if string[i].isspace():
            spa+=1
        elif string[i].isdigit():
            num+=1
        elif string[i].isalpha():
            alp+=1
        else:
            oth+=1
    print('space: ',spa)
    print('digit: ',num)
    print('alpha: ',alp)
    print('other: ',oth)
    
    

    实例018:复读机相加

    题目 求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制。

    程序分析 用字符串解决。

    a=input('被加数字:')
    n=int(input('加几次?:'))
    res=0
    for i in range(n):
        res+=int(a)
        a+=a[0]
    print('结果是:',res)
    

    实例019:完数

    题目 一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程找出1000以内的所有完数。

    程序分析 将每一对因子加进集合,在这个过程中已经自动去重。最后的结果要求不计算其本身。

    def factor(num):
        target=int(num)
        res=set()
        for i in range(1,num):
            if num%i==0:
                res.add(i)
                res.add(num/i)
        return res
    
    for i in range(2,1001):
        if i==sum(factor(i))-i:
            print(i)
    

    实例020:高空抛物

    题目 一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?

    程序分析

    high=200.
    total=100
    for i in range(10):
        high/=2
        total+=high
        print(high/2)
    print('总长:',total)
    

    实例021:猴子偷桃

    题目 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。

    程序分析 按规则反向推断:猴子有一个桃子,他偷来一个桃子,觉得不够又偷来了与手上等量的桃子,一共偷了9天。

    peach=1
    for i in range(9):
        peach=(peach+1)*2
    print(peach)
    

    实例022:比赛对手

    题目 两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。

    程序分析 找到条件下不重复的三个对手即可。

    a=set(['x','y','z'])
    b=set(['x','y','z'])
    c=set(['x','y','z'])
    c-=set(('x','z'))
    a-=set('x')
    for i in a:
        for j in b:
            for k in c:
                if len(set((i,j,k)))==3:
                    print('a:%s,b:%s,c:%s'%(i,j,k))
    

    实例023:画菱形

    题目 打印出如下图案(菱形):

        *
       ***
      *****
     *******
      *****
       ***
        *

    程序分析 递归调用即可。

    def draw(num):
        a="*"*(2*(4-num)+1)
        print(a.center(9,' '))
        if num!=1:
            draw(num-1)
            print(a.center(9,' '))
    draw(4)
    

    实例024:斐波那契数列II

    题目 有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的前20项之和。

    程序分析 就是斐波那契数列的后一项除以前一项。

    a = 2.0
    b = 1.0
    s = 0
    for n in range(1,21):
        s += a / b
        a,b = a + b,a
    print (s)
    
    

    实例025: 阶乘求和

    题目 求1+2!+3!+…+20!的和。

    程序分析 1+2!+3!+…+20!=1+2(1+3(1+4(…20(1))))

    res=1
    for i in range(20,1,-1):
        res=i*res+1
    print(res)
    

    实例026:递归求阶乘

    题目 利用递归方法求5!。

    程序分析 递归调用即可。

    def factorial(n):
        return n*factorial(n-1) if n>1 else 1
    print(factorial(5))
    

    实例027:递归输出

    题目 利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。

    程序分析 递归真是蠢方法。

    def rec(string):
        if len(string)!=1:
            rec(string[1:])
        print(string[0],end='')
    
    rec(input('string here:'))
    

    实例028:递归求等差数列

    题目 有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?

    程序分析 就一等差数列。

    def age(n):
        if n==1:
            return 10
        return 2+age(n-1)
    print(age(5))
    

    实例029:反向输出

    题目 给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。

    程序分析 学会分解出每一位数,用字符串的方法总是比较省事。

    n=int(input('输入一个正整数:'))
    n=str(n)
    print('%d位数'%len(n))
    print(n[::-1])
    

    实例030:回文数

    题目 一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

    程序分析 用字符串比较方便,就算输入的不是数字都ok。

    n=input("随便你输入啥啦:")
    a=0
    b=len(n)-1
    flag=True
    while a<b:
        if n[a]!=n[b]:
            print('不是回文串')
            flag=False
            break
        a,b=a+1,b-1
    if flag:
        print('是回文串')
    

    实例031:字母识词

    题目 请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。

    程序分析 这里用字典的形式直接将对照关系存好。

    weekT={'h':'thursday',
           'u':'tuesday'}
    weekS={'a':'saturday',
           'u':'sunday'}
    week={'t':weekT,
          's':weekS,
          'm':'monday',
          'w':'wensday',
          'f':'friday'}
    a=week[str(input('请输入第一位字母:')).lower()]
    if a==weekT or a==weekS:
        print(a[str(input('请输入第二位字母:')).lower()])
    else:
        print(a)
    
    

    实例032:反向输出II

    题目 按相反的顺序输出列表的值。

    程序分析 无。

    a = ['one', 'two', 'three']
    print(a[::-1])
    

    实例033:列表转字符串

    题目 按逗号分隔列表。

    程序分析 无。

    L = [1,2,3,4,5]
    print(','.join(str(n) for n in L))
    

    实例034:调用函数

    题目 练习函数调用。

    程序分析 无。

    def hello():
        print('Hello World!')
    def helloAgain():
        for i in range(2):
            hello()
    
    if __name__=='__main__':
        helloAgain()
    

    实例035:设置输出颜色

    题目 文本颜色设置。

    程序分析 无。

    class bcolors:
        HEADER = '\033[95m'
        OKBLUE = '\033[94m'
        OKGREEN = '\033[92m'
        WARNING = '\033[93m'
        FAIL = '\033[91m'
        ENDC = '\033[0m'
        BOLD = '\033[1m'
        UNDERLINE = '\033[4m'
    print(bcolors.WARNING + "警告的颜色字体?" + bcolors.ENDC)
    

    实例036:算素数

    题目 求100之内的素数。

    程序分析 用else执行for循环的奖励代码(如果for是正常完结,非break)。

    lo=int(input('下限:'))
    hi=int(input('上限:'))
    for i in range(lo,hi+1):
        if i > 1:
            for j in range(2,i):
                if (i % j) == 0:
                    break
            else:
                print(i)
    

    实例037:排序

    题目 对10个数进行排序。

    程序分析 同实例005。

    raw=[]
    for i in range(10):
        x=int(input('int%d: '%(i)))
        raw.append(x)
        
    for i in range(len(raw)):
        for j in range(i,len(raw)):
            if raw[i]>raw[j]:
                raw[i],raw[j]=raw[j],raw[i]
    print(raw)
    
    

    实例038:矩阵对角线之和

    题目 求一个3*3矩阵主对角线元素之和。

    程序分析 无。

    mat=[[1,2,3],
         [3,4,5],
         [4,5,6]
        ]
    res=0
    for i in range(len(mat)):
        res+=mat[i][i]
    print(res)
    

    实例039:有序列表插入元素

    题目 有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。

    程序分析 首先判断此数是否大于最后一个数,然后再考虑插入中间的数的情况,插入后此元素之后的数,依次后移一个位置。

    lis=[1,10,100,1000,10000,100000]
    n=int(input('insert a number: '))
    lis.append(n)
    for i in range(len(lis)-1):
        if lis[i]>=n:
            for j in range(i,len(lis)):
                lis[j],lis[-1]=lis[-1],lis[j]
            break
    print(lis)
    

    实例040:逆序列表

    题目 将一个数组逆序输出。

    程序分析 依次交换位置,或者直接调用reverse方法。

    lis=[1,10,100,1000,10000,100000]
    for i in range(int(len(lis)/2)):
        lis[i],lis[len(lis)-1-i]=lis[len(lis)-1-i],lis[i]
    print('第一种实现:')
    print(lis)
    
    
    lis=[1,10,100,1000,10000,100000]
    print('第二种实现:')
    lis.reverse()
    print(lis)
    
    

    实例041:类的方法与变量

    题目 模仿静态变量的用法。

    程序分析 构造类,了解类的方法与变量。

    def dummy():
        i=0
        print(i)
        i+=1
    
    class cls:
        i=0
        def dummy(self):
            print(self.i)
            self.i+=1
    
    a=cls()
    for i in range(50):
        dummy()
        a.dummy()
    

    实例042:变量作用域

    题目 学习使用auto定义变量的用法。

    程序分析 python中的变量作用域。

    i=0
    n=0
    def dummy():
        i=0
        print(i)
        i+=1
    def dummy2():
        global n
        print(n)
        n+=1
    print('函数内部的同名变量')
    for j in range(20):
        print(i)
        dummy()
        i+=1
    print('global声明同名变量')
    for k in range(20):
        print(n)
        dummy2()
        n+=10
    

    实例043:作用域、类的方法与变量

    题目 模仿静态变量(static)另一案例。

    程序分析 综合实例041和实例042。

    class dummy:
        num=1
        def Num(self):
            print('class dummy num:',self.num)
            print('global num: ',num)
            self.num+=1
    
    n=dummy()
    num=1
    for i in range(5):
        num*=10
        n.Num()
    

    实例044:矩阵相加

    题目 计算两个矩阵相加。

    程序分析 创建一个新的矩阵,使用 for 迭代并取出 X 和 Y 矩阵中对应位置的值,相加后放到新矩阵的对应位置中。

    X = [[12,7,3],
        [4 ,5,6],
        [7 ,8,9]]
     
    Y = [[5,8,1],
        [6,7,3],
        [4,5,9]]
     
    res=[[0,0,0],
        [0,0,0],
        [0,0,0]]
    for i in range(len(res)):
        for j in range(len(res[0])):
            res[i][j]=X[i][j]+Y[i][j]
    print(res)
    
    

    实例045:求和

    题目 统计 1 到 100 之和。

    程序分析

    res=0
    for i in range(1,101):
        res+=i
    print(res)
    

    实例046:打破循环

    题目 求输入数字的平方,如果平方运算后小于 50 则退出。

    程序分析

    while True:
        try:
            n=float(input('输入一个数字:'))
        except:
            print('输入错误')
            continue
        dn=n**2
        print('其平方为:',dn)
        if dn<50:
            print('平方小于50,退出')
            break
    

    实例047:函数交换变量

    题目 两个变量值用函数互换。

    程序分析

    def exc(a,b):
        return (b,a)
    a=0
    b=10
    a,b=exc(a,b)
    print(a,b)
    

    实例048:数字比大小

    题目 数字比较。

    程序分析

    a=int(input('a='))
    b=int(input('b='))
    if a<b:
        print('a<b')
    elif a>b:
        print('a>b')
    else:
        print('a=b')
    

    实例049:lambda

    题目 使用lambda来创建匿名函数。

    程序分析

    Max=lambda x,y:x*(x>=y)+y*(y>x)
    Min=lambda x,y:x*(x<=y)+y*(y<x)
    
    a=int(input('1:'))
    b=int(input('2:'))
    
    print(Max(a,b))
    print(Min(a,b))
    

    实例050:随机数

    题目 输出一个随机数。

    程序分析 使用 random 模块。

    import random
    print(random.uniform(10,20))
    

    实例051:按位与

    题目 学习使用按位与 & 。

    程序分析 0&0=0; 0&1=0; 1&0=0; 1&1=1。

    a=0o77
    print(a)
    b=a&3
    print(b)
    b=b&7
    print(b)
    

    实例052:按位或

    题目 学习使用按位或 | 。

    程序分析 0|0=0; 0|1=1; 1|0=1; 1|1=1

    a=0o77
    print(a|3)
    print(a|3|7)
    

    实例053:按位异或

    题目 学习使用按位异或 ^ 。

    程序分析 0^0=0; 0^1=1; 1^0=1; 1^1=0

    a=0o77
    print(a^3)
    print(a^3^7)
    

    实例054:位取反、位移动

    题目 取一个整数a从右端开始的4〜7位。

    程序分析 可以这样考虑:
    (1)先使a右移4位。
    (2)设置一个低4位全为1,其余全为0的数。可用(0<<4)
    (3)将上面二者进行&运算。

    a=int(input('输入一个数字: '))
    b=0                 #     0
    b=~b                #     1
    b=b<<4              # 10000
    b=~b                #  1111
    c=a>>4
    d=c&b
    print('a:',bin(a))
    print('b:',bin(b))
    print('c:',bin(c))
    print('d:',bin(d))
    

    实例055:按位取反

    题目 学习使用按位取反~。

    程序分析 ~0=1; ~1=0;

    print(~234)
    print(~~234)
    

    实例056:画圈

    题目 画图,学用circle画圆形。

    程序分析 无。

    from tkinter import *
    canvas=Canvas(width=800,height=600,bg='yellow')
    canvas.pack(expand=YES,fill=BOTH)
    k=1
    j=1
    for i in range(26):
        canvas.create_oval(310-k,250-k,310+k,250+k,width=1)
        k+=j
        j+=0.3
    mainloop()
    

    实例057:画线

    题目 画图,学用line画直线。

    程序分析 无。

    if __name__ == '__main__':
        from tkinter import *
     
        canvas = Canvas(width=300, height=300, bg='green')   
        canvas.pack(expand=YES, fill=BOTH)                  
        x0 = 263
        y0 = 263
        y1 = 275
        x1 = 275
        for i in range(19):
            canvas.create_line(x0,y0,x0,y1, width=1, fill='red')
            x0 = x0 - 5
            y0 = y0 - 5
            x1 = x1 + 5
            y1 = y1 + 5
     
        x0 = 263
        y1 = 275
        y0 = 263
        for i in range(21):
            canvas.create_line(x0,y0,x0,y1,fill = 'red')
            x0 += 5
            y0 += 5
            y1 += 5
     
        mainloop()
    

    实例058:画矩形

    题目 画图,学用rectangle画方形。

    程序分析 无。

    if __name__ == '__main__':
        from tkinter import *
        root = Tk()
        root.title('Canvas')
        canvas = Canvas(root,width = 400,height = 400,bg = 'yellow')
        x0 = 263
        y0 = 263
        y1 = 275
        x1 = 275
        for i in range(19):
            canvas.create_rectangle(x0,y0,x1,y1)
            x0 -= 5
            y0 -= 5
            x1 += 5
            y1 += 5
            
        canvas.pack()
        root.mainloop()
    

    实例059:画图(丑)

    题目 画图,综合例子。

    程序分析 丑。

    if __name__  == '__main__':
        from tkinter import *
        canvas = Canvas(width = 300,height = 300,bg = 'green')
        canvas.pack(expand = YES,fill = BOTH)
        x0 = 150
        y0 = 100
        canvas.create_oval(x0 - 10,y0 - 10,x0 + 10,y0 + 10)
        canvas.create_oval(x0 - 20,y0 - 20,x0 + 20,y0 + 20)
        canvas.create_oval(x0 - 50,y0 - 50,x0 + 50,y0 + 50)
        import math
        B = 0.809
        for i in range(16):
            a = 2 * math.pi / 16 * i
            x = math.ceil(x0 + 48 * math.cos(a))
            y = math.ceil(y0 + 48 * math.sin(a) * B)
            canvas.create_line(x0,y0,x,y,fill = 'red')
        canvas.create_oval(x0 - 60,y0 - 60,x0 + 60,y0 + 60)
        
    
        for k in range(501):
            for i in range(17):
                a = (2 * math.pi / 16) * i + (2 * math.pi / 180) * k
                x = math.ceil(x0 + 48 * math.cos(a))
                y = math.ceil(y0 + 48 + math.sin(a) * B)
                canvas.create_line(x0,y0,x,y,fill = 'red')
            for j in range(51):
                a = (2 * math.pi / 16) * i + (2* math.pi / 180) * k - 1
                x = math.ceil(x0 + 48 * math.cos(a))
                y = math.ceil(y0 + 48 * math.sin(a) * B)
                canvas.create_line(x0,y0,x,y,fill = 'red')
        mainloop()
    

    实例060:字符串长度

    题目 计算字符串长度。

    程序分析 无。

    s='zhangguang101'
    print(len(s))
    

    实例061:杨辉三角

    题目 打印出杨辉三角形前十行。

    程序分析 无。

    def generate(numRows):
        r = [[1]]
        for i in range(1,numRows):
            r.append(list(map(lambda x,y:x+y, [0]+r[-1],r[-1]+[0])))
        return r[:numRows]
    a=generate(10)
    for i in a:
        print(i)
    

    实例062:查找字符串

    题目 查找字符串。

    程序分析 无。

    s1='aabbxuebixuebi'
    s2='ab'
    s3='xue'
    print(s1.find(s2))
    print(s1.find(s3))
    

    实例063:画椭圆

    题目 画椭圆。

    程序分析 使用 tkinter。

    if __name__ == '__main__':
        from tkinter import *
        x = 360
        y = 160
        top = y - 30
        bottom = y - 30
        
        canvas = Canvas(width = 400,height = 600,bg = 'white')
        for i in range(20):
            canvas.create_oval(250 - top,250 - bottom,250 + top,250 + bottom)
            top -= 5
            bottom += 5
        canvas.pack()
        mainloop()
    

    实例064:画椭圆、矩形

    题目 利用ellipse 和 rectangle 画图。。

    程序分析 无。

    if __name__ == '__main__':
        from tkinter import *
        canvas = Canvas(width = 400,height = 600,bg = 'white')
        left = 20
        right = 50
        top = 50
        num = 15
        for i in range(num):
            canvas.create_oval(250 - right,250 - left,250 + right,250 + left)
            canvas.create_oval(250 - 20,250 - top,250 + 20,250 + top)
            canvas.create_rectangle(20 - 2 * i,20 - 2 * i,10 * (i + 2),10 * ( i + 2))
            right += 5
            left += 5
            top += 10
    
        canvas.pack()
        mainloop()
    

    实例065:画组合图形

    题目 一个最优美的图案。

    程序分析 无。

    import math
    from tkinter import *
    
    class PTS:
        def __init__(self):
            self.x = 0
            self.y = 0
    points = []
    
    def LineToDemo():
        screenx = 400
        screeny = 400
        canvas = Canvas(width = screenx,height = screeny,bg = 'white')
    
        AspectRatio = 0.85
        MAXPTS = 15
        h = screeny
        w = screenx
        xcenter = w / 2
        ycenter = h / 2
        radius = (h - 30) / (AspectRatio * 2) - 20
        step = 360 / MAXPTS
        angle = 0.0
        for i in range(MAXPTS):
            rads = angle * math.pi / 180.0
            p = PTS()
            p.x = xcenter + int(math.cos(rads) * radius)
            p.y = ycenter - int(math.sin(rads) * radius * AspectRatio)
            angle += step
            points.append(p)
        canvas.create_oval(xcenter - radius,ycenter - radius,
                           xcenter + radius,ycenter + radius)
        for i in range(MAXPTS):
            for j in range(i,MAXPTS):
                canvas.create_line(points[i].x,points[i].y,points[j].x,points[j].y)
    
        canvas.pack()
        mainloop()
    if __name__ == '__main__':
        LineToDemo()
    

    实例066:三数排序

    题目 输入3个数a,b,c,按大小顺序输出。

    程序分析 同实例005。

    raw=[]
    for i in range(3):
        x=int(input('int%d: '%(i)))
        raw.append(x)
        
    for i in range(len(raw)):
        for j in range(i,len(raw)):
            if raw[i]>raw[j]:
                raw[i],raw[j]=raw[j],raw[i]
    print(raw)
    
    
    raw2=[]
    for i in range(3):
        x=int(input('int%d: '%(i)))
        raw2.append(x)
    print(sorted(raw2))
    
    

    实例067:交换位置

    题目 输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。

    程序分析 无。

    li=[3,2,5,7,8,1,5]
    
    li[-1],li[li.index(min(li))]=li[li.index(min(li))],li[-1]
    
    m=li[0]
    ind=li.index(max(li))
    li[0]=li[ind]
    li[ind]=m
    
    print(li)
    

    实例068:旋转数列

    题目 有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数

    程序分析 无。

    from collections import *
    li=[1,2,3,4,5,6,7,8,9]
    deq=deque(li,maxlen=len(li))
    print(li)
    deq.rotate(int(input('rotate:')))
    print(list(deq))
    

    实例069:报数

    题目 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

    程序分析 无。

    if __name__ == '__main__':
        nmax = 50
        n = int(input('请输入总人数:'))
        num = []
        for i in range(n):
            num.append(i + 1)
     
        i = 0
        k = 0
        m = 0
     
        while m < n - 1:
            if num[i] != 0 : k += 1
            if k == 3:
                num[i] = 0
                k = 0
                m += 1
            i += 1
            if i == n : i = 0
     
        i = 0
        while num[i] == 0: i += 1
        print(num[i])
    

    实例070:字符串长度II

    题目 写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。

    程序分析 无。

    def lenofstr(s):
        return len(s)
    
    print(lenofstr('tanxiaofengsheng'))
    

    实例071:输入和输出

    题目 编写input()和output()函数输入,输出5个学生的数据记录。

    程序分析 无。

    N = 3
    #stu
    # num : string
    # name : string
    # score[4]: list
    student = []
    for i in range(5):
        student.append(['','',[]])
     
    def input_stu(stu):
        for i in range(N):
            stu[i][0] = input('input student num:\n')
            stu[i][1] = input('input student name:\n')
            for j in range(3):
                stu[i][2].append(int(input('score:\n')))
     
    def output_stu(stu):
        for i in range(N):
            print ('%-6s%-10s' % ( stu[i][0],stu[i][1] ))
            for j in range(3):
                print ('%-8d' % stu[i][2][j])
     
    if __name__ == '__main__':
        input_stu(student)
        print (student)
        output_stu(student)
    

    实例072:创建链表

    题目 创建一个链表。

    程序分析 原文不太靠谱。

    class Node:
    
        def __init__(self, data):
            self.data = data
            self.next = None
    
        def get_data(self):
            return self.data
    
    class List:
    
        def __init__(self, head):
            self.head = head
    
        def is_empty(self): 
            return self.get_len() == 0
    
        def get_len(self):  
            length = 0
            temp = self.head
            while temp is not None:
                length += 1
                temp = temp.next
            return length
    
        def append(self, node):
            temp = self.head
            while temp.next is not None:
                temp = temp.next
            temp.next = node
    
        def delete(self, index): 
            if index < 1 or index > self.get_len():
                print("给定位置不合理")
                return
            if index == 1:
                self.head = self.head.next
                return
            temp = self.head
            cur_pos = 0
            while temp is not None:
                cur_pos += 1
                if cur_pos == index-1:
                    temp.next = temp.next.next
                temp = temp.next
    
        def insert(self, pos, node):
            if pos < 1 or pos > self.get_len():
                print("插入结点位置不合理")
                return
            temp = self.head
            cur_pos = 0
            while temp is not Node:
                cur_pos += 1
                if cur_pos == pos-1:
                    node.next = temp.next
                    temp.next =node
                    break
                temp = temp.next
    
        def reverse(self, head):
            if head is None and head.next is None:
                return head
            pre = head
            cur = head.next
            while cur is not None:
                temp = cur.next
                cur.next = pre
                pre = cur
                cur = temp
            head.next = None
            return pre
    
        def print_list(self, head):
            init_data = []
            while head is not None:
                init_data.append(head.get_data())
                head = head.next
            return init_data
    
    if __name__=='__main__':
        head=Node('head')
        link=List(head)
        for i in range(10):
            node=Node(i)
            link.append(node)
        print(link.print_list(head))
    

    实例073:反向输出链表

    题目 反向输出一个链表。

    程序分析 无。

    class Node:
    
        def __init__(self, data):
            self.data = data
            self.next = None
    
        def get_data(self):
            return self.data
    
    class List:
    
        def __init__(self, head):
            self.head = head
    
        def is_empty(self): 
            return self.get_len() == 0
    
        def get_len(self):  
            length = 0
            temp = self.head
            while temp is not None:
                length += 1
                temp = temp.next
            return length
    
        def append(self, node):
            temp = self.head
            while temp.next is not None:
                temp = temp.next
            temp.next = node
    
        def delete(self, index): 
            if index < 1 or index > self.get_len():
                print("给定位置不合理")
                return
            if index == 1:
                self.head = self.head.next
                return
            temp = self.head
            cur_pos = 0
            while temp is not None:
                cur_pos += 1
                if cur_pos == index-1:
                    temp.next = temp.next.next
                temp = temp.next
    
        def insert(self, pos, node):
            if pos < 1 or pos > self.get_len():
                print("插入结点位置不合理")
                return
            temp = self.head
            cur_pos = 0
            while temp is not Node:
                cur_pos += 1
                if cur_pos == pos-1:
                    node.next = temp.next
                    temp.next =node
                    break
                temp = temp.next
    
        def reverse(self, head):
            if head is None and head.next is None:
                return head
            pre = head
            cur = head.next
            while cur is not None:
                temp = cur.next
                cur.next = pre
                pre = cur
                cur = temp
            head.next = None
            return pre
    
        def print_list(self, head):
            init_data = []
            while head is not None:
                init_data.append(head.get_data())
                head = head.next
            return init_data
    
    if __name__=='__main__':
        head=Node('head')
        link=List(head)
        for i in range(10):
            node=Node(i)
            link.append(node)
        print(link.print_list(head))
        print(link.print_list(link.reverse(head)))
    

    实例074:列表排序、连接

    题目 列表排序及连接。

    程序分析 排序可使用 sort() 方法,连接可以使用 + 号或 extend() 方法。

    a=[2,6,8]
    b=[7,0,4]
    a.extend(b)
    a.sort()
    print(a)
    

    实例075:不知所云

    题目 放松一下,算一道简单的题目。

    程序分析 鬼知道是什么。

    if __name__ == '__main__':
        for i in range(5):
            n = 0
            if i != 1: n += 1
            if i == 3: n += 1
            if i == 4: n += 1
            if i != 4: n += 1
            if n == 3: print (64 + i)
    

    实例076:做函数

    题目 编写一个函数,输入n为偶数时,调用函数求1/2+1/4+…+1/n,当输入n为奇数时,调用函数1/1+1/3+…+1/n

    程序分析 无。

    def peven(n):
        i = 0
        s = 0.0
        for i in range(2,n + 1,2):
            s += 1.0 / i
        return s
     
    def podd(n):
        s = 0.0
        for i in range(1, n + 1,2):
            s += 1.0 / i
        return s
     
    def dcall(fp,n):
        s = fp(n)
        return s
     
    if __name__ == '__main__':
        n = int(input('input a number: '))
        if n % 2 == 0:
            sum = dcall(peven,n)
        else:
            sum = dcall(podd,n)
        print (sum)
    

    实例077:遍历列表

    题目 循环输出列表

    程序分析 无。

    l=['moyu','niupi','xuecaibichi','shengfaji','42']
    for i in range(len(l)):
        print(l[i])
    

    实例078:字典

    题目 找到年龄最大的人,并输出。请找出程序中有什么问题。

    程序分析 无。

    if __name__ == '__main__':
        person = {"li":18,"wang":50,"zhang":20,"sun":22}
        m = 'li'
        for key in person.keys():
            if person[m] < person[key]:
                m = key
     
        print ('%s,%d' % (m,person[m]))
    

    实例079:字符串排序

    题目 字符串排序。

    程序分析 无。

    l=['baaa','aaab','aaba','aaaa','abaa']
    l.sort()
    print(l)
    

    实例080:猴子分桃

    题目 海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子平均分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,问海滩上原来最少有多少个桃子?

    程序分析 无。

    if __name__ == '__main__':
        i = 0
        j = 1
        x = 0
        while (i < 5) :
            x = 4 * j
            for i in range(0,5) :
                if(x%4 != 0) :
                    break
                else :
                    i += 1
                x = (x/4) * 5 +1
            j += 1
        print(x)
    
        for p in range(5):
            x=(x-1)/5*4
        print(x)
    

    实例081:求未知数

    题目 809*??=800*??+9*?? 其中??代表的两位数, 809*??为四位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。

    程序分析 无。

    a = 809
    for i in range(10,100):
        b = i * a
        if b >= 1000 and b <= 10000 and 8 * i < 100 and 9 * i >= 100:
            print(b,' = 800 * ', i, ' + 9 * ', i)
    
    
    for i in range(10,100):
        if 8*i>99 or 9*i<100:
            continue
        if 809*i==800*i+9*i:
            print(i)
            break
    

    实例082:八进制转十进制

    题目 八进制转换为十进制

    程序分析 无。

    n=eval('0o'+str(int(input('八进制输入:'))))
    print(n)
    

    实例083:制作奇数

    题目 求0—7所能组成的奇数个数。

    程序分析

    组成1位数是4个。1,3,5,7结尾

    组成2位数是7*4个。第一位不能为0

    组成3位数是7*8*4个。中间随意

    组成4位数是7*8*8*4个。

    if __name__ == '__main__':
        sum = 4
        s = 4
        for j in range(2,9):
            print (sum)
            if j <= 2:
                s *= 7
            else:
                s *= 8
            sum += s
        print('sum = %d' % sum)
    

    实例084:连接字符串

    题目 连接字符串。

    程序分析 无。

    delimiter = ','
    mylist = ['Brazil', 'Russia', 'India', 'China']
    print(delimiter.join(mylist))
    

    实例085:整除

    题目 输入一个奇数,然后判断最少几个 9 除于该数的结果为整数。

    程序分析 999999 / 13 = 76923。

    if __name__ == '__main__':
        zi = int(input('输入一个数字:'))
        n1 = 1
        c9 = 1
        m9 = 9
        sum = 9
        while n1 != 0:
            if sum % zi == 0:
                n1 = 0
            else:
                m9 *= 10
                sum += m9
                c9 += 1
        print ('%d 个 9 可以被 %d 整除 : %d' % (c9,zi,sum))
        r = sum / zi
        print ('%d / %d = %d' % (sum,zi,r))
    

    实例086:连接字符串II

    题目 两个字符串连接程序。

    程序分析 无。

    a='guangtou'
    b='feipang'
    print(b+a)
    

    实例087:访问类成员

    题目 回答结果(结构体变量传递)。

    程序分析 无。

    if __name__ == '__main__':
        class student:
            x = 0
            c = 0
        def f(stu):
            stu.x = 20
            stu.c = 'c'
        a= student()
        a.x = 3
        a.c = 'a'
        f(a)
        print(a.x,a.c)
    

    实例088:打印星号

    题目 读取7个数(1—50)的整数值,每读取一个值,程序打印出该值个数的*。

    程序分析 无。

    for i in range(3):
        print('*'*int(input('input a number: ')))
    

    实例089:解码

    题目 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。

    程序分析 无。

    n=input()
    n = str(n)
    a=[]
    for i in range(4):
        a.append((int(n[i])+5)%10)
    a[0],a[3]=a[3],a[0]
    a[1],a[2]=a[2],a[1]
    print ("".join('%s' %s for s in a))
    
    

    实例090:列表详解

    题目 列表使用实例。

    程序分析 无。

    #list  
    #新建列表  
    testList=[10086,'中国移动',[1,2,4,5]]  
      
    #访问列表长度  
    print (len(testList)  )
    #到列表结尾  
    print (testList[1:])
    #向列表添加元素  
    testList.append('i\'m new here!')  
      
    print (len(testList)  )
    print (testList[-1]  )
    #弹出列表的最后一个元素  
    print (testList.pop(1)  )
    print (len(testList)  )
    print (testList  )
    #list comprehension  
    #后面有介绍,暂时掠过  
    matrix = [[1, 2, 3],  
    [4, 5, 6],  
    [7, 8, 9]]  
    print (matrix  )
    print (matrix[1]  )
    col2 = [row[1] for row in matrix]#get a  column from a matrix  
    print (col2  )
    col2even = [row[1] for row in matrix if  row[1] % 2 == 0]#filter odd item  
    print (col2even)
    

    实例091:time模块

    题目 时间函数举例1。

    程序分析 无。

    if __name__ == '__main__':
        import time
        print (time.ctime(time.time()))
        print (time.asctime(time.localtime(time.time())))
        print (time.asctime(time.gmtime(time.time())))
    

    实例092:time模块II

    题目 时间函数举例2。

    程序分析 如何浪费时间。

    if __name__ == '__main__':
        import time
        start = time.time()
        for i in range(3000):
            print(i)
        end = time.time()
     
        print (end - start)
    

    实例093:time模块III

    题目 时间函数举例3。

    程序分析 如何浪费时间。

    if __name__ == '__main__':
        import time
        start = time.clock()
        for i in range(100):
            print(i)
        end = time.clock()
        print('different is %6.3f' % (end - start))
    

    实例094:time模块IV

    题目 时间函数举例4。

    程序分析 如何浪费时间。

    if __name__ == '__main__':
        import time
        import random
        
        play_it = input('do you want to play it.(\'y\' or \'n\')')
        while play_it == 'y':
            c = input('input a character:\n')
            i = random.randint(0,2**32) % 100
            print ('please input number you guess:\n')
            start = time.clock()
            a = time.time()
            guess = int(input('input your guess:\n'))
            while guess != i:
                if guess > i:
                    print('please input a little smaller')
                    guess = int(input('input your guess:\n'))
                else:
                    print('please input a little bigger')
                    guess = int(input('input your guess:\n'))
            end = time.clock()
            b = time.time()
            var = (end - start) / 18.2
            print (var)
            # print 'It took you %6.3 seconds' % time.difftime(b,a))
            if var < 15:
                print ('you are very clever!')
            elif var < 25:
                print ('you are normal!')
            else:
                print ('you are stupid!')
            print ('Congradulations')
            print ('The number you guess is %d' % i)
            play_it = input('do you want to play it.')
    

    实例095:转换时间格式

    题目 字符串日期转换为易读的日期格式。

    程序分析 看看就得了,dateutil是个第三方库。

    from dateutil import parser
    dt = parser.parse("Aug 28 2015 12:00AM")
    print (dt)
    

    实例096:计算复读次数

    题目 计算字符串中子串出现的次数。

    程序分析 无。

    s1='xuebixuebixuebixuebixuebixuebixuebixue'
    s2='xuebi'
    print(s1.count(s2))
    

    实例097:磁盘写入

    题目 从键盘输入一些字符,逐个把它们写到磁盘文件上,直到输入一个 # 为止。

    程序分析 无。

    if __name__ == '__main__':
        from sys import stdout
        filename = input('输入文件名:\n')
        fp = open(filename,"w")
        ch = input('输入字符串:\n')
        while ch != '#':
            fp.write(ch)
            stdout.write(ch)
            ch = input('')
        fp.close()
    

    实例098:磁盘写入II

    题目 从键盘输入一个字符串,将小写字母全部转换成大写字母,然后输出到一个磁盘文件"test"中保存。

    程序分析 无。

    if __name__ == '__main__':
        fp = open('test.txt','w')
        string = input('please input a string:\n')
        string = string.upper()
        fp.write(string)
        fp = open('test.txt','r')
        print (fp.read())
        fp.close()
    

    实例099:磁盘读写

    题目 有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列), 输出到一个新文件C中。

    程序分析 无。

    if __name__ == '__main__':
        import string
        fp = open('test1.txt')
        a = fp.read()
        fp.close()
     
        fp = open('test2.txt')
        b = fp.read()
        fp.close()
     
        fp = open('test3.txt','w')
        l = list(a + b)
        l.sort()
        s = ''
        s = s.join(l)
        fp.write(s)
        fp.close()
    

    实例100:列表转字典

    题目 列表转换为字典。

    程序分析 无。

    i = ['a', 'b']
    l = [1, 2]
    print (dict(zip(i,l)))
    
    展开全文
  • Android 超高仿微信图片选择器完整实例源码下载

    万次下载 热门讨论 2014-10-12 17:32:19
    代码为博客的实例代码,有问题请博客留言:http://blog.csdn.net/lmj623565791/article/details/39943731
  • VC++MFC小游戏实例教程(实例)+MFC类库详解

    千次下载 热门讨论 2013-09-12 18:39:38
    VC++MFC小游戏实例教程(实例)+MFC类库详解 免费下载
  • SwipeRefreshLayoutDemo 实例源码

    千次下载 热门讨论 2014-04-26 14:56:36
    代码为博客实例:http://blog.csdn.net/lmj623565791/article/details/24521483 有问题博客中留言
  • WebService实例

    千次下载 热门讨论 2013-10-15 10:11:40
    WebService实例,包含服务端和客户端,是两个Eclipse Project,可以直接引入,详细操作参照我的博客http://blog.csdn.net/ghsau/article/details/12714965。
  • SSH1框架搭建实例

    千次下载 热门讨论 2013-04-25 09:57:11
    SSH1框架搭建实例(spring2+struts1+hibernate3)采用旧版本 以资源分销系统物料维护为原型做实例。包括物料的增删改查。包括登录界面。
  • 文章目录不共享实例变量共享实例变量解决方案 不共享实例变量 测试代码 public class MyThreadNotShared extends Thread { private int count = 5; public MyThreadNotShared(String name){ super(); this.set...
  • JqueryFileUpload实例

    热门讨论 2014-08-11 14:13:23
    GitHub上JqueryFileUpload的实例,包括前后台,能实现文件上传,缩略图预览等功能,jdk1.7 Tomcat 7
  • SpringMVC+Hibernate+Spring整合实例

    千次下载 热门讨论 2013-05-31 15:49:34
    SpringMVC+Hibernate+Spring整合实例源码下载,很完整的例子,需要的可以下载源码学习
  • Nacos临时实例和持久化实例

    千次阅读 2020-11-01 19:34:04
    一、nacos两种健康检查模式 1.1 agent上报模式 客户端(注册在nacos上的其它微服务实例)健康检查。 ... 默认心跳间隔5秒;...nacos会在超过15秒未收到心跳后将实例设置为不健康状态;...临时实例通过agent上报模式实
  • 代码为博客实例代码 http://blog.csdn.net/lmj623565791/article/details/32964301 有问题博客中留言

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 5,105,570
精华内容 2,042,228
关键字:

实例