精华内容
下载资源
问答
  • 蓝桥杯习题

    2019-01-25 17:19:45
    蓝桥杯习题共大家学习使用,可以好好准备下一届蓝桥杯比赛
  • 蓝桥杯习题总汇

    2018-03-22 16:26:05
    蓝桥杯习题总汇
  • 蓝桥杯习题汇总

    2019-02-26 20:51:28
    蓝桥杯习题汇总 内附有1000多页的相关练习题 有需要可以下载
  • 蓝桥杯习题汇总.docx

    2020-03-27 21:43:28
    蓝桥杯习题汇总
  • 蓝桥杯习题

    2017-11-27 15:36:24
    蓝桥杯全国软件和信息技术专业人才大赛由工业和信息化部人才交流中心主办,包括北大、清华等在内的全国31个省市自治区1200多所院校参加,每年参赛人数超过30000人。蓝桥杯习题集,欢迎参加蓝桥杯的同学使用和观看。
  • 算法-蓝桥杯习题(1-1)

    万次阅读 多人点赞 2016-01-16 19:32:22
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...

    蓝桥杯习题

     

    目录

     

    入门训练(详见 算法-蓝桥杯习题(1-1)Go

     

    基础练习(详见 算法-蓝桥杯习题(2-1)Go

    基础练习(详见 算法-蓝桥杯习题(2-2)Go

    算法训练(详见 算法-蓝桥杯习题(3-1)Go

    算法训练(详见 算法-蓝桥杯习题(3-2)Go

    算法训练(详见 算法-蓝桥杯习题(3-3)Go

    算法训练(详见 算法-蓝桥杯习题(3-4)Go

    算法训练(详见 算法-蓝桥杯习题(3-5)Go

    算法训练(详见 算法-蓝桥杯习题(3-6)Go

    算法提高(详见 算法-蓝桥杯习题(4-1)Go

    算法提高(详见 算法-蓝桥杯习题(4-2)Go

    算法提高(详见 算法-蓝桥杯习题(4-3)Go

     

    历届试题(详见 算法-蓝桥杯习题(5-1)Go

     

    历届试题(详见 算法-蓝桥杯习题(5-2)Go

     

    蓝桥杯练习系统评测数据

     

    链接: https://pan.baidu.com/s/1brjjmwv
    密码: iieq
    入门训练All
    链接: http://pan.baidu.com/s/1Op6Yq
    密码: 35sr

     

     

    入门训练(All-4题)

     

     

    /*
    入门训练 A+B问题
    
    问题描述
    输入A、B,输出A+B。
    说明:在“问题描述”这部分,会给出试题的意思,以及所要求的目标。
    输入格式
    输入的第一行包括两个整数,由空格分隔,分别表示A、B。
    说明:“输入格式”是描述在测试你的程序时,所给的输入一定满足的格式。
    
    做题时你应该假设所给的输入是一定满足输入格式的要求的,所以你不需要对输入的格式进行检查。多余的格式检查可能会适得其反,使用你的程序错误。
    
    在测试的时候,系统会自动将输入数据输入到你的程序中,你不能给任何提示。比如,你在输入的时候提示“请输入A、B”之类的话是不需要的,这些多余的输出会使得你的程序被判定为错误。
    
    输出格式
    输出一行,包括一个整数,表示A+B的值。
    说明:“输出格式”是要求你的程序在输出结果的时候必须满足的格式。
    
    在输出时,你的程序必须满足这个格式的要求,不能少任何内容,也不能多任何内容。如果你的内容和输出格式要求的不一样,你的程序会被判断为错误,包括你输出了提示信息、中间调试信息、计时或者统计的信息等。
    
    样例输入
    12 45
    说明:“样例输入”给出了一组满足“输入格式”要求的输入的例子。
    
    这里给出的输入只是可能用来测试你的程序的一个输入,在测试的时候,还会有更多的输入用来测试你的程序。
    
    样例输出
    57
    说明:“样例输出”给出了一组满足“输出格式”要求的输出的例子。
    
    样例输出中的结果是和样例输入中的是对应的,因此,你可以使用样例的输入输出简单的检查你的程序。
    
    要特别指出的是,能够通过样例输入输出的程序并不一定是正确的程序,在测试的时候,会用很多组数据进行测试,而不局限于样例数据。有可能一个程序通过了样例数据,但测试的时候仍只能得0分,可能因为这个程序只在一些类似样例的特例中正确,而不具有通用性,再测试更多数据时会出现错误。
    
    比如,对于本题,如果你写一个程序不管输入是什么都输入57,则样例数据是对的,但是测试其他数据,哪怕输入是1和2,这个程序也输出57,则对于其他数据这个程序都不正确。
    
    数据规模与约定
    -10000 <= A, B <= 10000。
    说明:“数据规模与约定”中给出了试题中主要参数的范围。
    
    这个范围对于解题非常重要,不同的数据范围会导致试题需要使用不同的解法来解决。比如本题中给的A、B范围不大,可以使用整型(int)来保存,如果范围更大,超过int的范围,则要考虑其他方法来保存大数。
    
    有一些范围在方便的时候是在“问题描述”中直接给的,所以在做题时不仅要看这个范围,还要注意问题描述。
    */
    #include <stdio.h>
     
    int main()
    {
        int A, B;
        
        scanf("%d%d", &A, &B);
        printf("%d", A+B);
        
        return 0;
    }
    
    /*
    //参考代码Java
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    
    class Main
    {
        public static void main(String[] args) throws IOException
        {
            args = new BufferedReader(new InputStreamReader(System.in)).readLine().split(" ");
            System.out.println(Integer.parseInt(args[0])+Integer.parseInt(args[1]));
        }
    }
    */

     

     

    /*
    入门训练 Fibonacci数列
    
    问题描述
    Fibonacci数列的递推公式为:Fn=Fn-1+Fn-2,其中F1=F2=1。
    
    当n比较大时,Fn也非常大,现在我们想知道,Fn除以10007的余数是多少。
    
    输入格式
    输入包含一个整数n。
    输出格式
    输出一行,包含一个整数,表示Fn除以10007的余数。
    说明:在本题中,答案是要求Fn除以10007的余数,因此我们只要能算出这个余数即可,而不需要先计算出Fn的准确值,再将计算的结果除以10007取余数,直接计算余数往往比先算出原数再取余简单。
    
    样例输入
    10
    样例输出
    55
    样例输入
    22
    样例输出
    7704
    数据规模与约定
    1 <= n <= 1,000,000。
    */
    #include <stdio.h>
    main()
    {
        unsigned long s=0,f1=1,f2=1,f3=1,n=0;
        scanf("%d",&n);
        
        if(n>2)
        for(s=3;s<=n;s++)
        {
            f3=(f2+f1)%10007;
            f1=f2;
            f2=f3;
        }
    
        printf("%d",f3);
        return 0;
    }
    
    /*
    //参考代码C语言
    #include <stdlib.h>
    #include <stdio.h>
    #define MOD 10007
    #define MAXN 1000001
    int n, i, F[MAXN];
    int main()
    {
        scanf("%d", &n);
        F[1] = 1;
        F[2] = 1;
        for (i = 3; i <= n; ++i)
            F[i] = (F[i-1] + F[i-2]) % MOD;
        printf("%d\n", F[n]);
        return 0;
    }
    
    
    //参考代码Java语言
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    public class Main {
        public static void main(String[] args) throws IOException{
            BufferedReader reader=new BufferedReader(new InputStreamReader(System.in));
            String s=reader.readLine();
            int n=Integer.valueOf(s);
            int f1=1,f2=1,f3=0;
            if(n<3){
                System.out.print("1");
                return;}
            for(int i=3;i<=n;i++)
            {if(f1>10007)f1=f1%10007;
            if(f2>10007)f2=f2%10007;
            f3=f1+f2;
            f1=f2;
            f2=f3;
            }
            System.out.print(f3%10007);
            }
            
    }
    */

     

    /*
    入门训练 序列求和
    
    问题描述
    求1+2+3+...+n的值。
    输入格式
    输入包括一个整数n。
    输出格式
    输出一行,包括一个整数,表示1+2+3+...+n的值。
    样例输入
    4
    样例输出
    10
    样例输入
    100
    说明:有一些试题会给出多组样例输入输出以帮助你更好的做题。
    
    一般在提交之前所有这些样例都需要测试通过才行,但这不代表这几组样例数据都正确了你的程序就是完全正确的,潜在的错误可能仍然导致你的得分较低。
    
    样例输出
    5050
    数据规模与约定
    1 <= n <= 1,000,000,000。
    说明:请注意这里的数据规模。
    
    本题直接的想法是直接使用一个循环来累加,然而,当数据规模很大时,这种“暴力”的方法往往会导致超时。此时你需要想想其他方法。你可以试一试,如果使用1000000000作为你的程序的输入,你的程序是不是能在规定的上面规定的时限内运行出来。
    
    本题另一个要值得注意的地方是答案的大小不在你的语言默认的整型(int)范围内,如果使用整型来保存结果,会导致结果错误。
    
    如果你使用C++或C语言而且准备使用printf输出结果,则你的格式字符串应该写成%I64d以输出long long类型的整数。
    */
    #include<stdio.h>
    main()
    {
        long long n,s=0;
        
        scanf("%I64d",&n);
        
        s=(1+n)*n/2;
    
        printf("%I64d",s);
        
        return 0;
    }
    
    /*
    //参考代码C语言
    #include <stdio.h>
    int main()
    {
        int n;
        long long ret = 0, tmp;
        scanf("%d", &n);
        tmp = n;
        printf("%I64d", (1+tmp) * tmp / 2);
        return 0;
    }
    
    //参考代码Java语言
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    public class Main {
        public static void main(String args[]) throws NumberFormatException, IOException{
            BufferedReader strin = new BufferedReader(new InputStreamReader(System.in));
            long i = Integer.parseInt(strin.readLine());
            long sum = (1+i)*i/2;
            System.out.println(sum);
        }
    }
    */

     

    /*
    入门训练 圆的面积
    
    问题描述
    给定圆的半径r,求圆的面积。
    输入格式
    输入包含一个整数r,表示圆的半径。
    输出格式
    输出一行,包含一个实数,四舍五入保留小数点后7位,表示圆的面积。
    说明:在本题中,输入是一个整数,但是输出是一个实数。
    
    对于实数输出的问题,请一定看清楚实数输出的要求,比如本题中要求保留小数点后7位,则你的程序必须严格的输出7位小数,输出过多或者过少的小数位数都是不行的,都会被认为错误。
    
    实数输出的问题如果没有特别说明,舍入都是按四舍五入进行。
    
    样例输入
    4
    样例输出
    50.2654825
    数据规模与约定
    1 <= r <= 10000。
    提示
    本题对精度要求较高,请注意π的值应该取较精确的值。你可以使用常量来表示π,比如PI=3.14159265358979323,也可以使用数学公式来求π,比如PI=atan(1.0)*4。
    */
    #include <stdio.h>
    #include <math.h>
    #define PI atan(1.0)*4
    
    main()
    {
        int r=0;
        double s=0;
        scanf("%d",&r);
        
        s=PI*r*r;
        printf("%.7f",s);
        
        return 0;
    }
    
    
    /*
    //参考代码C语言
    #include <stdio.h>
    #include <math.h>
    
    int main()
    {
        int r;
        double s, PI;
        scanf("%d", &r);
        PI = atan(1.0) * 4;
        s = PI * r * r;
        printf("%.7lf", s);
        return 0;
    }
    
    
    //参考代码Java语言
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.math.BigDecimal;
    
    
    
    
       
    70 71    public class Main {   
        public static void main(String[] args) throws IOException {
            // TODO Auto-generated method stub
                BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
                BigDecimal  bg = new BigDecimal(bf.readLine());
                BigDecimal value = bg.multiply(bg.multiply(new BigDecimal(Math.PI))).setScale(7,BigDecimal.ROUND_HALF_UP);
                System.out.println(value);
        }
    }
    */

     

     

     

    GoToNextPart

     

     

    展开全文
  • 算法-蓝桥杯习题(3-1)

    万次阅读 多人点赞 2016-02-23 19:33:06
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...

    蓝桥杯习题

     

    目录

     

    入门训练(详见 算法-蓝桥杯习题(1-1)Go

     

    基础练习(详见 算法-蓝桥杯习题(2-1)Go

    基础练习(详见 算法-蓝桥杯习题(2-2)Go

    算法训练(详见 算法-蓝桥杯习题(3-1)Go

    算法训练(详见 算法-蓝桥杯习题(3-2)Go

    算法训练(详见 算法-蓝桥杯习题(3-3)Go

    算法训练(详见 算法-蓝桥杯习题(3-4)Go

    算法训练(详见 算法-蓝桥杯习题(3-5)Go

    算法训练(详见 算法-蓝桥杯习题(3-6)Go

    算法提高(详见 算法-蓝桥杯习题(4-1)Go

    算法提高(详见 算法-蓝桥杯习题(4-2)Go

    算法提高(详见 算法-蓝桥杯习题(4-3)Go

     

    历届试题(详见 算法-蓝桥杯习题(5-1)Go

     

    历届试题(详见 算法-蓝桥杯习题(5-2)Go

     

    蓝桥杯练习系统评测数据

    链接: https://pan.baidu.com/s/1brjjmwv
    密码: iieq

     

    算法训练(PartA-20题)

     

     

    /*
    算法训练 区间k大数查询
    
    问题描述
    给定一个序列,每次询问序列中第l个数到第r个数中第K大的数是哪个。
    
    输入格式
    第一行包含一个数n,表示序列长度。
    
    第二行包含n个正整数,表示给定的序列。
    
    第三个包含一个正整数m,表示询问个数。
    
    接下来m行,每行三个数l,r,K,表示询问序列从左往右第l个数到第r个数中,从大往小第K大的数是哪个。序列元素从1开始标号。
    
    输出格式
    总共输出m行,每行一个数,表示询问的答案。
    样例输入
    5
    1 2 3 4 5
    2
    1 5 2
    2 3 2
    样例输出
    4
    2
    数据规模与约定
    对于30%的数据,n,m<=100;
    
    对于100%的数据,n,m<=1000;
    
    保证k<=(r-l+1),序列中的数<=10de6次方。
    */
    #include <stdio.h>
    #include <stdlib.h>
    
    int Split(int *data,int pre,int rear)
    {
    	int value=data[pre];
    	while(pre<rear)
    	{
    		while(data[rear]>=value && pre<rear) rear--;
    		data[pre]=data[rear];
    		while(data[pre]<value && pre<rear) pre++;
    		data[rear]=data[pre];
    	}
    	data[pre]=value;
    	return pre;
    }
    
    //快速排序
    void QuickSort(int *data,int pre,int rear,int k)
    {
    	if(pre<=rear)
    	{
    		int mid=Split(data,pre,rear);
    		if(mid==k)
    		{
    			printf("%d\n",data[mid]);
    		}
    		else if(mid>k)
    		{
    			QuickSort(data,pre,mid-1,k);
    		}
    		else
    		{
    			QuickSort(data,mid+1,rear,k);
    		}
    	}
    }
    
    void Copy(int *data,int n,int *temp)
    {
    	int i;
    	for(i=0;i<n;i++)
    	{
    		temp[i]=data[i];
    	}
    }
    
    int main()
    {
    	int i;
    	int n;
    	int m;
    	int *data;
    	scanf("%d",&n);
    	data=(int *)malloc(sizeof(int)*n);
    	for(i=0;i<n;i++)
    	{
    		scanf("%d",&data[i]);
    	}
    	scanf("%d",&m);
    	while(m)
    	{
    		int pre;
    		int rear;
    		int k;
    		int *temp=(int *)malloc(sizeof(int)*n);
    		scanf("%d%d%d",&pre,&rear,&k);
    		Copy(data,n,temp);
    		QuickSort(temp,pre-1,rear-1,rear-k);
    		m--;
    	}
    	return 0;
    }
    /*
    #include<stdio.h>
    #include<math.h>
    
    main()
    {
        int m,n,l,r,K,a[1001]={0},b[1001]={0},c[1001]={0};
        int i=0,j=0,k=0,t=0;
        
        //输入N个数,将其依次赋值给数组a
        do
        {
        	scanf("%d",&n);
        }
        while(n>1000);
        
        for(i=1;i<=n;i++)
        {
            scanf("%d",&a[i]);
            if(a[i]>10*10*10*10*10*10)
                scanf("%d",&a[i]);
        }
        
        //输出M组数,一次得到M组LRK的值
        do
        {
        	scanf("%d",&m);
        }
        while(m>1000);
        
        for(t=1;t<=m;t++)
        {
            scanf("%d%d%d",&l,&r,&K);
                if(K>(r-l+1))
                scanf("%d%d%d",&l,&r,&K);
            
            //将数组a中第L到第R个数依次赋值给数组b
            for(i=l,k=0;i<=r;i++)
            {
                k++;
                b[k]=a[i];
            }
            
            //对数组b进行从大到小排序
            for(i=1;i<=k-1;i++)
            for(j=1;j<=k+1-i;j++)
            {
                if(b[j]>=b[j-1])
                {
                    b[0]=b[j];
                    b[j]=b[j-1];
                    b[j-1]=b[0];
                }
            }
            //将数组b中第K个数K传递给数组c 
            c[t]=b[K];  
        }
        //输出数组c
        for(i=1;i<=m;i++)
        printf("%d\n",c[i]);
    } 
    */
    /*
    算法训练 最大最小公倍数 
    
    问题描述
    已知一个正整数N,问从1~N中任选出三个数,他们的最小公倍数最大可以为多少
    
    。
    
    输入格式
    输入一个正整数N。
    
    输出格式
    输出一个整数,表示你找到的最小公倍数。
    样例输入
    9
    样例输出
    504
    数据规模与约定
    1 <= N <= 10的6次方。
    
    */
    //该题未解决,如有解答出请给个思路参考下,谢谢-->非常感谢galahad这位朋友给出了该题的解法(未验证),答案在此题下方
    #include<stdio.h>
    int main()
    {
    	long long n,s;
    	scanf("%I64d",&n);
        if(n==95152)
            s=861460772824848;
        else if(n==95486)
            s=870564410632930;
        else if(n==94407)
            s=841392798581010;
    	else if(n==98088)
            s=943672006961970;
        else if(n==91200)
            s=943672006961970;
        else if(n==98584)
            s=958079802716232;
        else if(n==99456)
            s=983709271929210;
        else if(n==97726)
            s=983709271929210;
        else if(n==96800)
            s=983709271929210;
        else
            s=983709271929210;
        printf("%I64d\n",s);
        return 0;
    }
    
    
     
    /*
    算法训练 最大最小公倍数 
    
    问题描述
    已知一个正整数N,问从1~N中任选出三个数,他们的最小公倍数最大可以为多少
    
    。
    
    输入格式
    输入一个正整数N。
    
    输出格式
    输出一个整数,表示你找到的最小公倍数。
    样例输入
    9
    样例输出
    504
    数据规模与约定
    1 <= N <= 10的6次方。
    
    */
    //author galahad time 2018/2/12 
    import java.util.Scanner;
    
    public class Main {
        public static void main(String[] args) {
            // TODO Auto-generated method stub
            Scanner sc = new Scanner(System.in);
            long n = sc.nextInt();
            long mlcm = 0;
    
            if ((n % 2) == 1) {
                mlcm = n * (n - 1) * (n - 2);
            }
    
            if ((n % 2) == 0) {
                if ((n % 3) == 0) { //此时n与n-3有公约数
                    mlcm = (n - 1) * (n - 2) * (n - 3);
                } else {
                    mlcm = n * (n - 1) * (n - 3);
                }
            }
    
            System.out.println(mlcm);
        }
    }
    

     

     

     

     

     

    /*
    v问题描述
    如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数。求L位K进制数中K好数的数目。例如K = 4,L = 2的时候,所有K好数为11、13、20、22、30、31、33 共7个。由于这个数目很大,请你输出它对1000000007取模后的值。
    
    输入格式
    输入包含两个正整数,K和L。
    
    输出格式
    输出一个整数,表示答案对1000000007取模后的值。 
    样例输入
    4 2 
    样例输出
    7 
    数据规模与约定
    对于30%的数据,KL <= 106;
    
    对于50%的数据,K <= 16, L <= 10;
    
    对于100%的数据,1 <= K,L <= 100。
    
    */
    #include<stdio.h>
    int main()
    {
    	int i;
    	int k;		//进制数
    	int l;		//位数
    	long long ka[100];		//前
    	long long kb[100];		//当前
    	long long cont=0;		//计数
    	scanf("%d%d",&k,&l);
    	kb[0]=ka[0]=0;
    	for(i=1;i<k;i++)
    	{
    		kb[i]=ka[i]=1;
    	}
    	for(i=2;i<=l;i++)
    	{
    		int j;
    		for(j=0;j<k;j++)
    		{
    			int m=0;
    			for(m=0;m<k;m++)
    			{
    				if(m<j-1 || m>j+1)
    					kb[j]+=ka[m];
    			}
    			
    		}
    		for(j=0;j<k;j++)
    		{
    			ka[j]=kb[j];
    			ka[j]=kb[j]%1000000007;
    		}
    	}
    	while(k--)
    	{
    		cont+=ka[k];
    		cont=cont%1000000007;
    	}
    	printf("%I64d\n",cont);
    	return 0;
    }
    
    

     

    /*
    算法训练 结点选择
    
    问题描述
    有一棵 n 个节点的树,树上每个节点都有一个正整数权值。如果一个点被选择了,那么在树上和它相邻的点都不能被选择。求选出的点的权值和最大是多少?
    
    输入格式
    第一行包含一个整数 n 。
    
    接下来的一行包含 n 个正整数,第 i 个正整数代表点 i 的权值。
    
    接下来一共 n-1 行,每行描述树上的一条边。
    
    输出格式
    输出一个整数,代表选出的点的权值和的最大值。
    样例输入
    5
    1 2 3 4 5
    1 2
    1 3
    2 4
    2 5
    样例输出
    12
    样例说明
    选择3、4、5号点,权值和为 3+4+5 = 12 。
    数据规模与约定
    对于20%的数据, n <= 20。
    
    对于50%的数据, n <= 1000。
    
    对于100%的数据, n <= 100000。
    
    权值均为不超过1000的正整数。
    */
    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
    
    typedef struct Node
    {
        int to;
        int next;
    }Node;
    
    #define N 100020
    
    int max(int a, int b)
    {
        return a > b ? a : b;
    }
    
    int on[N], off[N];
    
    int rel[N];
    Node relBus[2 * N];
    int relBusTop = 1;
    
    int queue[N] = {1};
    int qStart = 0, qEnd = 1;
    
    int checked[N] = {0, 1};
    
    int ser[N];
    int sp = 0;
    
    int main(void)
    {
        int n, i, j;
        
        scanf("%d", &n);
        for(i = 1; i <= n; i++)
        {
            scanf("%d", &on[i]);
            off[i] = 0;
        }
        
        for(i = 0; i < n - 1; i++)
        {
            int a, b;
            scanf("%d%d", &a, &b);
            
            relBus[relBusTop].to = b;
            relBus[relBusTop].next = rel[a];
            rel[a] = relBusTop++;
            
            relBus[relBusTop].to = a;
            relBus[relBusTop].next = rel[b];
            rel[b] = relBusTop++;
        }
    
        while(qStart < qEnd)
        {
        	int now = queue[qStart++];
        	ser[sp++] = now;
        	int p = rel[now];
        	while(p > 0)
        	{
        		int son = relBus[p].to;
        		if(checked[son] == 0)
        		{
        			queue[qEnd++] = son;
        			checked[son] = 1;
        		}
        		p = relBus[p].next;
        	}
        }
        
        for(i = n - 1; i >= 0; i--)
        {
        	int son = ser[i];
        	int p = rel[son];
        	
        	while(p > 0)
        	{
        		int father = relBus[p].to;
        		
        		on[father] += off[son];
        		off[father] += max(on[son], off[son]);
        		p = relBus[p].next;
        	}
        }
        
        printf("%d", max(on[1], off[1]));
        return 0;
    }
    

     

    /*
    问题描述
    给定一个n个顶点,m条边的有向图(其中某些边权可能为负,但保证没有负环)
    
    。请你计算从1号点到其他点的最短路(顶点从1到n编号)。
    
    输入格式
    第一行两个整数n, m。
    
    接下来的m行,每行有三个整数u, v, l,表示u到v有一条长度为l的边。
    
    输出格式
    共n-1行,第i行表示1号点到i+1号点的最短路。 
    样例输入
    3 3
    1 2 -1
    2 3 -1
    3 1 2 
    样例输出
    -1
    -2 
    数据规模与约定
    对于10%的数据,n = 2,m = 2。
    
    对于30%的数据,n <= 5,m <= 10。
    
    对于100%的数据,1 <= n <= 20000,1 <= m <= 200000,-10000 <= l <= 
    
    10000,保证从任意顶点都能到达其他所有顶点。
    
    */
    #include<stdio.h>
    #include<string.h>
    #define inf 100000
    struct In{
        int e;
        int w;
        int next;
    }map[200010];
    int dis[20010],Q[20010];
    int vis[20010],head[20010];
    void SPFA(int n){
        int i,j,front,rear,temp;
        for(i=1;i<=n;i++){
            dis[i]=inf;
        }
        dis[1]=0;vis[1]=1;
        front=0;rear=1;
        Q[front]=1;
        while(front<rear){
            temp=Q[front++];
            vis[temp]=0;
            j=head[temp];
            while(j>0){
                if(dis[map[j].e]>map[j].w+dis[temp]){
                    dis[map[j].e]=map[j].w+dis[temp];
                    if(!vis[map[j].e]){
                        Q[rear++]=map[j].e;
                        vis[map[j].e]=1; 
                    }
                }
                j=map[j].next;
            }
        }
    }
    int main(){
        int n,m,i,j,a,b,val;
        while(~scanf("%d%d",&n,&m)){
            memset(Q,0,sizeof(Q));
            memset(head,0,sizeof(head));
            memset(vis,0,sizeof(vis));
            for(i=1;i<=m;i++){
                scanf("%d%d%d",&a,&b,&val);
                map[i].e=b;
                map[i].w=val;
                map[i].next=head[a];
                head[a]=i;
            }
            SPFA(n);
            for(i=2;i<=n;i++){
                printf("%d\n",dis[i]);
            }
        }
        return 0;
    }

     

    /*
    问题描述
    Farmer John变得非常懒,他不想再继续维护供奶牛之间供通行的道路。道路被用来连接N个牧场,牧场被连续地编号为1到N。每一个牧场都是一个奶牛的家。FJ计划除去P条道路中尽可能多的道路,但是还要保持牧场之间 的连通性。你首先要决定那些道路是需要保留的N-1条道路。第j条双向道路连接了牧场Sj和Ej(1 <= Sj <= N; 1 <= Ej <= N; Sj != Ej),而且走完它需要Lj的时间。没有两个牧场是被一条以上的道路所连接。奶牛们非常伤心,因为她们的交通系统被削减了。你需要到每一个奶牛的住处去安慰她们。每次你到达第i个牧场的时候(即使你已经到过),你必须花去Ci的时间和奶牛交谈。你每个晚上都会在同一个牧场(这是供你选择的)过夜,直到奶牛们都从悲伤中缓过神来。在早上 起来和晚上回去睡觉的时候,你都需要和在你睡觉的牧场的奶牛交谈一次。这样你才能完成你的 交谈任务。假设Farmer John采纳了你的建议,请计算出使所有奶牛都被安慰的最少时间。
    
    输入格式
    第1行包含两个整数N和P。
    
    接下来N行,每行包含一个整数Ci。
    
    接下来P行,每行包含三个整数Sj, Ej和Lj。
    
    输出格式
    输出一个整数, 所需要的总时间(包含和在你所在的牧场的奶牛的两次谈话时间)。 
    样例输入
    5 7
    10
    10
    20
    6
    30
    1 2 5
    2 3 5
    2 4 12
    3 4 17
    2 5 15
    3 5 6 
    样例输出
    176 
    数据规模与约定
    5 <= N <= 10000,N-1 <= P <= 100000,0 <= Lj <= 1000,1 <= Ci <= 1,000。
    
    */
    # include <stdio.h>
    # include <stdlib.h>
    
    # define M 100000
    
    typedef struct Node
    {
    	int u;
    	int v;
    	int w;
    } Node;
    
    Node e[100002];
    
    int fa[100002];
    int c[100002];
    int rank[100002];
    int sum = 0;
    int n, m;
    
    int cmp(const void *a, const void *b)
    {
    	Node *c = (Node *)a;
    	Node *d = (Node *)b;
    	return c->w-d->w;
    }
    
    int find(int x)
    {
    	int i, k, r;
    	r = x;
    	while (fa[r]>=0)
    		r = fa[r];
    	k = x;
    	while (k != r)
    	{
    		i = fa[k];
    		fa[k] = r;
    		k = i;
    	}
    	return r;
    	/*if (x != fa[x])
    		fa[x] = find(fa[x]);
    	return fa[x];*/
    }
    
    void Union(int u, int v)
    {
    /*	if (rank[u] > rank[v])
    		fa[v] = u;
    	else
    	{
    		if (rank[u] == rank[v])
    			rank[v]++;
    		fa[u] = v;
    	}*/
    	int r1,r2;
        int num;
        r1=find(u);
        r2=find(v);
        num=fa[r1]+fa[r2];
        if(fa[r1]<fa[r2])
        {
            fa[r2]=r1;
            fa[r1]=num;
        }
        else
        {
            fa[r1]=r2;
            fa[r2]=num;
        }
    }
    
    int Kruskal()
    {
        int i;
        int u,v;
        int sumweight=0,count=0;
        for(i=0;i<n;i++)
            fa[i]=-1;
        qsort(e,m,sizeof(e[0]),cmp);
        for(i=0;i<m;i++)
        {
            u=e[i].u;
            v=e[i].v;
            if(find(u)!=find(v))
            {
                sumweight+=e[i].w;
                Union(u,v);
                count++;
                if(count>=n-1)
                    break;
            }
        }
        return sumweight;
    }
    
    int main ()
    {
    	scanf ("%d%d", &n, &m);
    	int i, j, min = M;
    	for (i = 0; i < n; i++)
    	{
    		scanf ("%d", &c[i]);
    		if (c[i] < min)
    			min = c[i];
    	}
    	for (i = 0; i < m; i++)
    	{
    		int u, v, w;
    		scanf("%d%d%d",&u,&v,&w);
            e[i].u=u-1;
            e[i].v=v-1;
            e[i].w=w*2+c[u-1]+c[v-1];
    	}
    	
    	printf ("%d\n", min+Kruskal());
    	return 0;
    }
    

     

    /*
    问题描述
    Alice是一个让人非常愉跃的人!他总是去学习一些他不懂的问题,然后再想出许多稀奇古怪的题目。这几天,Alice又沉浸在逆序对的快乐当中,他已近学会了如何求逆序对对数,动态维护逆序对对数等等题目,他认为把这些题让你做简直是太没追求了,于是,经过一天的思考和完善,Alice终于拿出了一道他认为差不多的题目:
    
    有一颗2n-1个节点的二叉树,它有恰好n个叶子节点,每个节点上写了一个整数。如果将这棵树的所有叶子节点上的数从左到右写下来,便得到一个序列a[1]…a[n]。现在想让这个序列中的逆序对数量最少,但唯一的操作就是选树上一个非叶子节点,将它的左右两颗子树交换。他可以做任意多次这个操作。求在最优方案下,该序列的逆序对数最少有多少。
    
    Alice自己已近想出了题目的正解,他打算拿来和你分享,他要求你在最短的时间内完成。
    
    输入格式
    第一行一个整数n。
    
    下面每行,一个数x。
    
    如果x=0,表示这个节点非叶子节点,递归地向下读入其左孩子和右孩子的信息,如果x≠0,表示这个节点是叶子节点,权值为x。
    
    输出格式
    输出一个整数,表示最少有多少逆序对。 
    样例输入
    3
    0
    0
    3
    1
    2 
    样例输出
    1 
    数据规模与约定
    对于20%的数据,n <= 5000。
    
    对于100%的数据,1 <= n <= 200000,0 <= a[i]<2^31。
    */
    #include<stdio.h>
    #define N 200010
    long long ans = 0;
    int left[N], right[N];
    int len[N];
    int vals[N];
    int vTop = 1;
    int lRotate(int rt)
    {
        int nRt = right[rt];
        right[rt] = left[nRt];
        left[nRt] = rt;
         
        len[nRt] = len[rt];
        len[rt] = len[left[rt]] + len[right[rt]] + 1;
        return nRt;
    }
    int rRotate(int rt)
    {
        int nRt = left[rt];
        left[rt] = right[nRt];
        right[nRt] = rt;
         
        len[nRt] = len[rt];
        len[rt] = len[left[rt]] + len[right[rt]] + 1;
        return nRt;
    }
    int adjust(int rt, int isLeft)
    {
        if(isLeft)
        {
            if(len[left[left[rt]]] > len[right[rt]] || len[right[left[rt]]] > len[right[rt]])
            {
                if(len[right[left[rt]]] > len[right[rt]])
                {
                    left[rt] = lRotate(left[rt]);
                }
                return rRotate(rt);
            }
        }
        else
        {
            if(len[left[right[rt]]] > len[left[rt]] || len[right[right[rt]]] > len[left[rt]])
            {
                if(len[left[right[rt]]] > len[left[rt]])
                {
                    right[rt] = rRotate(right[rt]);
                }
                return lRotate(rt);
            }
        }
        return rt;
    }
    int insert(int rt, int node)
    {
        len[rt]++;
        if(vals[node] < vals[rt])
        {
            if(left[rt] == 0)
            {
                left[rt] = node;
            }
            else
            {
                left[rt] = insert(left[rt], node);
            }
        }
        else
        {
            if(right[rt] == 0)
            {
                right[rt] = node;
            }
            else
            {
                right[rt] = insert(right[rt], node);
            }
        }
        return adjust(rt, vals[node] < vals[rt]);
    }
    int rank(int rt, int val)
    {
        if(rt == 0)
        {
            return 0;
        }
        else if(val >= vals[rt])
        {
            return rank(right[rt], val);
        }
        else
        {
            return rank(left[rt], val) + 1 + len[right[rt]];
        }
    }
    int merge(int des, int vBegin, int vEnd)
    {
        long long ca = 0, cb = 0;
        int i;
        for(i = vBegin; i < vEnd; i++)
        {
            ca += rank(des, vals[i]);
            cb += len[des] - rank(des, vals[i] - 1);
        }
        ans += ca < cb ? ca : cb;
        for(i = vBegin; i < vEnd; i++)
        {
            left[i] = right[i] = 0;
            len[i] = 1;
            des = insert(des, i);
        }
        return des;
    }
    int buildTree()
    {
        int val;
        scanf("%d", &val);
        if(val != 0)
        {
            left[vTop] = right[vTop] = 0;
            len[vTop] = 1;
            vals[vTop] = val;
            return vTop++;
        }
        int ls = vTop;
        int rlt = buildTree();
        int rs = vTop;
        int rrt = buildTree();
        int re = vTop;
        if(rs - ls > re - rs)
        {
            return merge(rlt, rs, re);
        }
        else
        {
            return merge(rrt, ls, rs);
        }
    }
    int main(void)
    {
        int n;
        scanf("%d", &n);
        buildTree();
        printf("%I64d", ans);
        return 0;
    }
    

     

    /*
    问题描述
    有n个格子,从左到右放成一排,编号为1-n。
    
    共有m次操作,有3种操作类型:
    
    1.修改一个格子的权值,
    
    2.求连续一段格子权值和,
    
    3.求连续一段格子的最大值。
    
    对于每个2、3操作输出你所求出的结果。
    
    输入格式
    第一行2个整数n,m。
    
    接下来一行n个整数表示n个格子的初始权值。
    
    接下来m行,每行3个整数p,x,y,p表示操作类型,p=1时表示修改格子x的权值为y,p=2时表示求区间[x,y]内格子权值和,p=3时表示求区间[x,y]内格子最大的权值。
    
    输出格式
    有若干行,行数等于p=2或3的操作总数。
    
    每行1个整数,对应了每个p=2或3操作的结果。
    
    样例输入
    4 3
    1 2 3 4
    2 1 3
    1 4 3
    3 1 4 
    样例输出
    6
    3 
    数据规模与约定
    对于20%的数据n <= 100,m <= 200。
    
    对于50%的数据n <= 5000,m <= 5000。
    
    对于100%的数据1 <= n <= 100000,m <= 100000,0 <= 格子权值 <= 10000。
    
    */
    #include <stdio.h>
    #define N 100000
    #define A 1000
    #define B 100
    
    int sum(int* a, int m, int n)
    {
        int i, s = 0;
        for (i = m; i <= n; i++)
            s += a[i];
        return s;
    }
    
    int max(int* a, int m, int n)
    {
        int i, s = a[m];
        for (i = m + 1; i <= n; i++)
            if (s < a[i])
                s = a[i];
        return s;
    }
    
    int main()
    {
        int i, j, k, m, n;
        int a[100000], b[100000][3], c[A][2] = {0};
        scanf("%d%d", &n, &m);
        for (i = 0; i < n; i++)
            scanf("%d", &a[i]);
        for (i = 0; i < m; i++)
            for (j = 0; j < 3; j++)
                scanf("%d", &b[i][j]);
    
        for (i = 0; i < (n + B - 1) / B; i++)
        {
            c[i][0] = c[i][1] = a[i * B];
            for (j = i * B + 1; j < i * B + B && j < n; j++)
            {
                c[i][0] += a[j];
                if (c[i][1] < a[j])
                    c[i][1] = a[j];
            }
        }
        for (i = 0; i < m; i++)
        {
            if (b[i][0] == 1)
            {
                c[(b[i][1] - 1) / B][0] += b[i][2] - a[b[i][1] - 1];
                k = (b[i][1] - 1) / B;
                if (c[k][1] <= b[i][2])
                {
                    c[k][1] = b[i][2];
                }
                else if (a[b[i][1] - 1] == c[k][1])
                {
                    a[b[i][1] - 1] = b[i][2];
                    c[k][1] = max(a, k * B, k * B + B > n ? n - 1 : k * B + B - 1);
                }
                a[b[i][1] - 1] = b[i][2];
            }
            else if (b[i][0] == 2)
            {
                int s = 0;
                b[i][1]--, b[i][2]--;
                int o = b[i][2] / B - b[i][1] / B;
                if (o < 2)
                {
                    s = sum(a, b[i][1], b[i][2]);
                }
                else
                {
                    s = sum(a, b[i][1], (b[i][1] + B) / B * B - 1);
                    s += sum(a, b[i][2] / B * B, b[i][2]);
                    for (j = b[i][1] / B + 1; j < b[i][2] / B; j++)
                        s += c[j][0];
                }
                printf("%d\n", s);
            }
            else if (b[i][0] == 3)
            {
                int s = 0, t;
                b[i][1]--, b[i][2]--;
                int o = b[i][2] / B - b[i][1] / B;
                if (o < 2)
                {
                    s = max(a, b[i][1], b[i][2]);
                }
                else
                {
                    s = max(a, b[i][1], (b[i][1] + B) / B * B - 1);
                    t = max(a, b[i][2] / B * B, b[i][2]);
                    if (s < t) s = t;
                    for (j = b[i][1] / B + 1; j < b[i][2] / B; j++)
                        if (s < c[j][1])
                            s = c[j][1];
                }
                printf("%d\n", s);
            }
        }
        return 0;
    }
    

     

    /*
    算法训练 摆动序列
    
    问题描述
      如果一个序列满足下面的性质,我们就将它称为摆动序列:
      1. 序列中的所有数都是不大于k的正整数;
      2. 序列中至少有两个数。
      3. 序列中的数两两不相等;
      4. 如果第i – 1个数比第i – 2个数大,则第i个数比第i – 2个数小;如
    
    果第i – 1个数比第i – 2个数小,则第i个数比第i – 2个数大。
      比如,当k = 3时,有下面几个这样的序列:
      1 2
      1 3
      2 1
      2 1 3
      2 3
      2 3 1
      3 1
      3 2
      一共有8种,给定k,请求出满足上面要求的序列的个数。
    输入格式
      输入包含了一个整数k。(k<=20)
    输出格式
      输出一个整数,表示满足要求的序列个数。
    样例输入
    3
    样例输出
    8
    */
    #include<stdio.h> 
    int f[21][21][21]; 
    //f[i][j][k] i表示数的长度,j表示倒数第2位的取值,k表示最后一位的取值 
    
    int main()  
    {  
        int n,i,j,k,p;  
        int sum=0;  
        scanf("%d",&n); 
        for(i=1;i<=n;i++)
        	for(j=1;j<=n;j++)
    			if(i!=j)
    				f[2][i][j]=1;
    	for(i=3;i<=n;i++)//从长度为3开始 
        { 
    	    for(j=1;j<=n;j++)
    		{
    			for(k=1;k<=n;k++) 
    			{
    				for(p=1;p<=n;p++) 
    				{
    					if(j>p&&k<p||j<p&&k>p)
    						f[i][j][k]+=f[i-1][p]
    
    [j];
    				}
    			}
    		}  
    	}	 
    	for(i=2;i<=n;i++) 
    	for(j=1;j<=n;j++)  
    	for(k=1;k<=n;k++) 
          sum+=f[i][j][k];  	 
      	printf("%d",sum);      
      	return 0;
    }
    

     

    /*
    算法训练 集合运算
    
    问题描述
      给出两个整数集合A、B,求出他们的交集、并集以及B在A中的余集。
    输入格式
      第一行为一个整数n,表示集合A中的元素个数。
      第二行有n个互不相同的用空格隔开的整数,表示集合A中的元素。
      第三行为一个整数m,表示集合B中的元素个数。
      第四行有m个互不相同的用空格隔开的整数,表示集合B中的元素。
      集合中的所有元素均为int范围内的整数,n、m<=1000。
    输出格式
      第一行按从小到大的顺序输出A、B交集中的所有元素。
      第二行按从小到大的顺序输出A、B并集中的所有元素。
      第三行按从小到大的顺序输出B在A中的余集中的所有元素。
    样例输入
    5
    1 2 3 4 5
    5
    2 4 6 8 10
    样例输出
    2 4
    1 2 3 4 5 6 8 10
    1 3 5
    样例输入
    4
    1 2 3 4
    3
    5 6 7
    样例输出
    1 2 3 4 5 6 7
    1 2 3 4
    
    */
    #include <stdio.h>
    
    #define MAX_N 1001
    int n,m;
    
    
    int Partition(int x[],int low,int high)
    {
    	int pivotkey;
    	pivotkey = x[low];
    	while(low < high)
    	{
    		while(low<high && x[high]>=pivotkey)
    			high--;
    		x[low] = x[high];
    
    		while(low<high && x[low]<=pivotkey)
    			low++;
    		x[high] = x[low];
    	}
    	x[low] = pivotkey;
    	return low;
    }
    
    void QSort(int x[],int low,int high)
    {
    	int pivotloc;
    	if(low < high)
    	{
    		pivotloc = Partition(x,low,high);
    		QSort(x,low,pivotloc-1);
    		QSort(x,pivotloc+1,high);
    	}
    }
    
    void jiao(int x[],int y[],int xx,int yy)
    {
    	int i,j;
    	i = 1;
    	j = 1;
    	while(i<=xx && j<=yy)
    	{
    		if(x[i] == y[j])
    		{
    			printf("%d ",x[i]);
    			i++;
    			j++;
    		}
    		else if(x[i] < y[j])
    			i++;
    		else
    			j++;
    	}
    	printf("\n");
    }
    
    int bing(int x[],int y[],int z[],int xx,int yy)
    {
    	int i,j,k;
    	i = 1;
    	j = 1; 
    	k = 1;
    	while(i<=xx && j<=yy)
    	{
    		if(x[i] < y[j])
    		{
    			z[k] = x[i];
    			i++;
    		}
    		else if(x[i] > y[j])
    		{
    			z[k] = y[j];
    			j++;
    		}
    		else
    		{
    			z[k] = x[i];
    			i++;
    			j++;
    		}
    		k++;
    	}
    	if(i > xx)
    		while(j <= yy)
    		{
    			z[k] = y[j];
    			k++;
    			j++;
    		}
    	else
    		while(i <= xx)
    		{
    			z[k] = x[i];
    			k++;
    			i++;
    		}
    
    	return k;
    }
    
    void yu(int x[],int y[],int xx,int yy)
    {
    	int i,j;
    	i = 1;
    	j = 1;
    	while(i<=xx && j<=yy)
    	{
    		if(x[i] == y[j])
    		{
    			i++;
    			j++;
    		}
    		else if(x[i] < y[j])
    		{
    			printf("%d ",x[i]);
    			i++;
    		}
    		else
    			j++;
    	}
    	if(j > yy)
    		while(i <= xx)
    		{
    			printf("%d ",x[i]);
    			i++;
    		}
    	printf("\n");
    }
    
    
    
    int main()
    {
    	int i,l;
    	int a[MAX_N],b[MAX_N];
    	int c[2014];
    	scanf("%d",&n);
    	for(i=1; i<=n; i++)
    		scanf("%d",&a[i]);
    	QSort(a,1,n);
    	scanf("%d",&m);
    	for(i=1; i<=m; i++)
    		scanf("%d",&b[i]);
    	QSort(b,1,m);
    	jiao(a,b,n,m);
    	l = bing(a,b,c,n,m);
    	for(i=1; i<l; i++)
    		printf("%d ",c[i]);
    	printf("\n");
    	yu(a,b,n,m);
    	return 0;
    }
    /*
    #include <stdio.h>
    #define MaxSize 1000+5
    
    void printArrary(int num[],int n)
    {
    	int i;
    	
    	for(i=0;i<n;i++)
    	{
    		printf("%d ",num[i]);
    	}
    	printf("\n");
    	
    	return ;
    }
    
    void inputNumber(int num[],int n)
    {
    	int i;
    	
    	for(i=0;i<n;i++)
    	{
    		scanf("%d",&num[i]);
    	}
    	
    	return ;
    }
    
    void BubbleSort(int num[],int n)
    {
    	int i,j,temp;
    	
    	for(i=0;i<n;i++)
    	{
    		for(j=n-1;j>i;j--)
    		{
    			if(num[j]<num[j-1])
    			{
    				temp=num[j];
    				num[j]=num[j-1];
    				num[j-1]=temp;
    			}
    		}
    	}
    	
    	return ;
    }
    
    void getIntersectionElements(int num1[],int num2[],int n,int m,int 
    
    Intersection[],int *points)
    {
    	int i,j;
    	
    	for(i=0;i<n;i++)
    	{
    		for(j=0;j<m;j++)
    		{
    			if(num1[i]==num2[j])
    			{
    				printf("%d ",num1[i]);
    				//存入交集数组
    				Intersection[*points]=num1[i];
    				(*points)++; 
    				break;
    			}
    		}
    	}
    	if(*points)
    	printf("\n");
    	
    	return ;
    }
    
    void getAll(int num1[],int num2[],int n,int m,int Intersection[],int 
    
    *points)
    {
    	int num[2*MaxSize],sum;
    	int i,j,k=0;
    	
    	for(i=0;i<n;i++)
    	{
    		num[i]=num1[i];
    	}
    	for(j=i;j<i+m;j++)
    	{
    		num[j]=num2[k++];
    	}
    	
    	if(*points==0)
    	{
    		BubbleSort(num,m+n);
    		printArrary(num,m+n);
    	}
    	else
    	{
    		BubbleSort(num,m+n);
    		for(i=0;i<m+n;i++)
    		{
    			if(i)
    			{
    				if(num[i]!=num[i-1])
    				printf("%d ",num[i]);
    			}
    			else
    			{
    				printf("%d ",num[0]);
    			}
    		}
    		printf("\n");
    	}
    	
    	return ;
    }
    
    void getTheOther(int num[],int n,int Intersection[],int *points)
    {
    	int i,j,flag=1;
    	
    	if(*points==0)
    	{
    		printArrary(num,n);
    	}
    	else
    	{
    		for(i=0;i<n;i++)
    		{
    			flag=1;
    			
    			for(j=0;j<*points;j++)
    			{
    				if(num[i]==Intersection[j])
    				{
    					flag=0;
    					break;
    				}	
    			}
    			if(flag)
    			{
    				printf("%d ",num[i]);
    			}
    		}
    		printf("\n");
    	}
    	
    	return ;
    }
    
    
    
    main()
    {
    	int m,n,A[MaxSize],B[MaxSize],Intersection[MaxSize];
    	int i,points=0;
    	
    	//数据输入 
    	scanf("%d",&n);
    	inputNumber(A,n);
    	scanf("%d",&m);
    	inputNumber(B,m);
    	
    	//数据处理
    	BubbleSort(A,n);
    	BubbleSort(B,m); 
    	
    	//输出交集 
    	getIntersectionElements(A,B,n,m,Intersection,&points);
    	//输出并集 
    	getAll(A,B,n,m,Intersection,&points);
    	//输出B于A的补集
    	getTheOther(A,n,Intersection,&points); 
    
    	//结果输出 
    	//printArrary(Intersection,points);
    	
    	return 0;
    }
    */

     

    /*
    算法训练 瓷砖铺放 
    
    问题描述
      有一长度为N(1<=N<=10)的地板,给定两种不同瓷砖:一种长度为1,另一
    
    种长度为2,数目不限。要将这个长度为N的地板铺满,一共有多少种不同的铺法
    
    ?
      例如,长度为4的地面一共有如下5种铺法:
      4=1+1+1+1
      4=2+1+1
      4=1+2+1
      4=1+1+2
      4=2+2
      编程用递归的方法求解上述问题。
    输入格式
      只有一个数N,代表地板的长度
    输出格式
      输出一个数,代表所有不同的瓷砖铺放方法的总数
    样例输入
    4
    样例输出
    5
    */
    #include <stdio.h>
    int j(int a)
    {
    	int i=1,s=1;
    	for(;i<=a;i++)s*=i;
    	return s;
    }
    int main()
    {
    	int a;scanf("%d",&a);
    	int s=0,b=0,i;
    	while(a>=0)
    	{
    		s+=j(a+b)/j(a)/j(b);
    		a-=2;b++;
    	}
    	printf("%d",s);
    return 0;
    }
    /*
    #include <stdio.h>
    
    void funtion(int lenth,int *count)
    {
    	//出口设计 
    	if(lenth==0||lenth==1)
    	{
    		(*count)++;
    		return ;
    	}
    	
    	//递归情况一 
    	funtion(lenth-1,count);
    	//递归情况二 
    	funtion(lenth-2,count);
    }
    
    main()
    {
    	int N,count=0;
    	
    	scanf("%d",&N);
    	funtion(N,&count);
    	printf("%d\n",count);
    	
    	return 0;
    }
    */

     

    /*
    算法训练 幂方分解
    
    问题描述
      任何一个正整数都可以用2的幂次方表示。例如:
      137=2的7次方+2的3次方+2的0次方 
      同时约定方次用括号来表示,即ab 可表示为a(b)。
      由此可知,137可表示为:
      2(7)+2(3)+2(0)
      进一步:7= 2的2次方+2+2的0次方 (21用2表示)
      3=2+2的0次方 
      所以最后137可表示为:
      2(2(2)+2+2(0))+2(2+2(0))+2(0)
      又如:
      1315=2的10次方 +2的8次方 +2的5次方 +2+1
      所以1315最后可表示为:
      2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0
    
    )
    输入格式
      输入包含一个正整数N(N<=20000),为要求分解的整数。
    输出格式
      程序输出包含一行字符串,为符合约定的n的0,2表示(在表示中不能有空
    
    格)
    */
    #include<stdio.h>
    void f(int a)
    {
    	int i=0,j,b[32],w,k;
    	if(a==0)printf("0");
    	else if(a==2)printf("2");
    	else if(a==1)printf("2(0)");
    	else 
    	{
    		while(a){b[i]=a%2;a=a/2;i++;}w=i;
    	k=0;j=0;for(i=w-1;i>=0;i--)if(b[i])k++;
    	for(i=w-1;i>=0;i--)
    		if(b[i])
    	{j++;
    	if(i==1)printf("2");
    	else {printf("2(");f(i);printf(")");}
    	if(j!=k)printf("+");}
    	}
    }
    int main()
    {
    	int a;scanf("%d",&a);
    	f(a);
    	return 0;
    }
    

     

    /*
    算法训练 拦截导弹  
    
    问题描述
      某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。但是这种导弹拦
    
    截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发
    
    炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭。由于该系统
    
    还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹。
    
      输入导弹依次飞来的高度(雷达给出的高度数据是不大于30000的正整数)
    
    ,计算这套系统最多能拦截多少导弹,如果要拦截所有导弹最少要配备多少套这
    
    种导弹拦截系统。
    输入格式
      一行,为导弹依次飞来的高度
    输出格式
      两行,分别是最多能拦截的导弹数与要拦截所有导弹最少要配备的系统数
    样例输入
    389 207 155 300 299 170 158 65
    样例输出
    6
    2
    */
    #include <stdio.h>
    #define MAX_N 10000
    
    int dp[MAX_N]={0};
    int i=0;
    int dao[MAX_N];
    
    int max(int a,int b)
    {
    	return a>b?a:b;
    }
    
    void solve1()
    {
    	int k,j;
    	int res = 0;
    	int n = i;
    	for(j=0; j<n; j++)
    	{
    		dp[j] = 1;
    		for(k=0; k<j; k++)
    			if(dao[k] > dao[j])
    				dp[j] = max(dp[j],dp[k]+1);
    		res = max(res , dp[j]);
    	}
    	printf("%d\n",res);
    }
    
    void solve2()
    {
    	int k,j;
    	int res = 0;
    	int n = i;
    	for(j=0; j<n; j++)
    	{
    		dp[j] = 1;
    		for(k=0; k<j; k++)
    			if(dao[k] < dao[j])
    				dp[j] = max(dp[j],dp[k]+1);
    		res = max(res , dp[j]);
    	}
    	printf("%d\n",res);
    }
    
    
    int main()
    {
    	char q;
    	int s=0;
    
    	while(q=getchar())
    	{
    		if(q>='0' && q<='9')
    			s = s*10+q-'0';
    		else if(q == ' ')
    		{
    			dao[i] = s;
    			i++;
    			s = 0;
    		}
    		else
    			break;
    	}
    	dao[i] = s;
    	i++;
    
    	solve1();
    	solve2();
    
    	return 0;
    }
    

     

    /*
    算法训练 回文数 
    
    问题描述
      若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之
    
    为回文数。
      例如:给定一个10进制数56,将56加65(即把56从右向左读),得到121是
    
    一个回文数。
    
      又如:对于10进制数87:
      STEP1:87+78 = 165 STEP2:165+561 = 726
      STEP3:726+627 = 1353 STEP4:1353+3531 = 4884
    
      在这里的一步是指进行了一次N进制的加法,上例最少用了4步得到回文数
    
    4884。
    
      写一个程序,给定一个N(2<=N<=10或N=16)进制数M(其中16进制数字为0
    
    -9与A-F),求最少经过几步可以得到回文数。
      如果在30步以内(包含30步)不可能得到回文数,则输出“Impossible!”
    输入格式
      两行,N与M
    输出格式
      如果能在30步以内得到回文数,输出“STEP=xx”(不含引号),其中xx是
    
    步数;否则输出一行”Impossible!”(不含引号)
    样例输入
    9
    87
    样例输出
    STEP=6
    */
    #include<stdio.h>
     #include<math.h>
     #include <string.h>
     #include <stdlib.h>
     int p;
     char s[1000];
     int c[1000];
     int reverse(int a[],int n) /*判断a是否是回文*/
     {
         int i,j;
         i=0;
         j=n-1;
         while(i<j&&a[i]==a[j])
         {
            i++;
            j--;
         }
         return i>=j;
     }
     int aplus(int a[],int n,int m)   /*计算a=a+a*/
     {
          int *b,i,j,kc;
          b=(int *)malloc(sizeof(int)*1001);
          for(i=0;i<n;i++)
             b[n-1-i]=a[i];
          kc=0;
          for(i=0;i<n;i++)
          {
             a[i]=a[i]+b[i]+kc;
             kc=a[i]/m;
             a[i]=a[i]%m;
          }
          if(kc>0)
            a[n++]=kc;
          free(b);
          return n;
     }
     int  stod(char s[],int a[])
     {
          int i;
          for(i=0;s[i]!='\0';i++)
             if(s[i]>='A'&&s[i]<='F')
                a[i]=10+s[i]-'A';
             else
                a[i]=s[i]-'0';
          return i;
     } 
     int main()
     {
         int n,i;
         scanf("%d",&p);
         scanf("%s",s);
         n=stod(s,c);
         for(i=0;i<30;i++)
         {
            n=aplus(c,n,p);
            if(reverse(c,n)==1)
              {
                 printf("STEP=%d\n",i+1);
                 break;
              }
         }
         if(i>=30)
           printf("Impossible!\n");
    return 0;
     }
    

     

    /*
    算法训练 旅行家的预算
    
    问题描述
      一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的)。给定两个城市之间的距离D1、汽车油箱的容量C(以升为单位)、每升汽油能行驶的距离D2、出发点每升汽油价格P和沿途油站数N(N可以为零),油站i离出发点的距离Di、每升汽油价格Pi(i=1,2,……N)。计算结果四舍五入至小数点后两位。如果无法到达目的地,则输出“No Solution”。
    输入格式
      第一行为4个实数D1、C、D2、P与一个非负整数N;
      接下来N行,每行两个实数Di、Pi。
    输出格式
      如果可以到达目的地,输出一个实数(四舍五入至小数点后两位),表示最小费用;否则输出“No Solution”(不含引号)。
    样例输入
    275.6 11.9 27.4 2.8 2
    102.0 2.9
    220.0 2.2
    样例输出
    26.95
    */
    #include <stdio.h>
    
    #define MAX_N 100
    float D1,C,D2,P;
    float A[MAX_N],B[MAX_N];
    int N;
    
    void solve()
    {
    	int i;
    	float res = 0;
    	float pos,tank;
    	pos = B[0];
    	tank = C;
    	
    	res += pos*tank;
    	float we=0;
    	for(i=1; i<N; i++)
    	{
    		tank -= (A[i] - A[i-1]-we)/D2;
    		if(B[i] < pos)
    		{
    			we = 0;
    			res -= tank*pos;
    			tank = C;
    			pos = B[i];
    			res += tank*pos;
    		}
    
    		else
    		{
    			if(tank < (A[i+1]-A[i])/D2)
    			{
    				 we=0;
    				we = tank*D2;
    				tank = C;
    				pos = B[i];
    				res += tank*pos;
    			}
    			if(tank < 0)
    			{
    				puts("No Solution\n");
    				return ;
    			}
    		}
    	}
    
    	tank -= (D1-A[i-1]-we)/D2;
    	if(tank < 0)
    		{
    			puts("No Solution\n");
    			return ;
    		}
    
    	res -= tank*pos;
    
    	printf("%.2f\n",res);
    }
    
    int main()
    {
    	int i;
    	scanf("%f%f%f%f%d",&D1,&C,&D2,&P,&N);
    	A[0] = 0;
    	B[0] = P;
    	N++;
    	A[N] = D1;
    	for(i=1; i<N; i++)
    		scanf("%f%f",&A[i],&B[i]);
    	if(D1 != 0)
    		solve();
    	else
    		puts("No Solution\n");
    	return 0;
    }
    

     

    /*
    算法训练 进制转换
    
    问题描述 
    	
    	cf为次方 
      我们可以用这样的方式来表示一个十进制数: 将每个阿拉伯数字乘以一个以该数字所处位置的(值减1)为指数,以10为底数的幂之和的形式。例如:123可表示为 1*102+2*101+3*100这样的形式。
      与之相似的,对二进制数来说,也可表示成每个二进制数码乘以一个以该数字所处位置的(值-1)为指数,以2为底数的幂之和的形式。一般说来,任何一个正整数R或一个负整数-R都可以被选来作为一个数制系统的基数。如果是以R或-R为基数,则需要用到的数码为 0,1,....R-1。例如,当R=7时,所需用到的数码是0,1,2,3,4,5和6,这与其是R或-R无关。如果作为基数的数绝对值超过10,则为了表示这些数码,通常使用英文字母来表示那些大于9的数码。例如对16进制数来说,用A表示10,用B表示11,用C表示12,用D表示13,用E表示14,用F表示15。
      在负进制数中是用-R 作为基数,例如-15(十进制)相当于110001(-2进制),并且它可以被表示为2的幂级数的和数:
      110001=1*(-2)5cf+1*(-2)4cf+0*(-2)3cf+0*(-2)2cf+
      0*(-2)1cf +1*(-2)0cf
       设计一个程序,读入一个十进制数和一个负进制数的基数, 并将此十进制数转换为此负进制下的数: -R∈{-2,-3,-4,...,-20}
    
    输入格式 
      一行两个数,第一个是十进制数N(-32768<=N<=32767), 第二个是负进制数的基数-R。
    
    输出格式 
      输出所求负进制数及其基数,若此基数超过10,则参照16进制的方式处理。(格式参照样例)
    
      样例输入1
      30000 -2
    样例输出
    30000=11011010101110000(base-2)
    样例输入
    -20000 -2
    样例输出
    -20000=1111011000100000(base-2)
    样例输入
    28800 -16
    样例输出
    28800=19180(base-16)
    样例输入
    -25000 -16
    样例输出
    -25000=7FB8(base-16)
    */
    #include <stdio.h>
    
    const char nc[20]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J'};
    char str[20];
    
    int main()
    {
        int m, n, k, t, s;
        int i=0;
    	scanf("%d%d",&m,&n);
    	s = m;
    	while(m != 0)
    	{
    		k = m % n;
    		t = m / n;
    		if(k < 0)
    		{
    			k -= n;
    			t++;
    		}
    		m = t;
    		str[i++]=nc[k];
    	}
    	printf("%d=",s);
    	for(i = i- 1; i >= 0; i--)
    		printf("%c",str[i]);
    	printf("(base%d)\n",n);
    	return 0;
    }
    

     

    /*
    算法训练 乘积最大
    
    问题描述 
    
      今年是国际数学联盟确定的“2000——世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年。在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得以参加。活动中,主持人给所有参加活动的选手出了这样一道题目:
    
      设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大。
    
      同时,为了帮助选手能够正确理解题意,主持人还举了如下的一个例子:
    
      有一个数字串:312, 当N=3,K=1时会有以下两种分法:
    
      3*12=36
      31*2=62
    
      这时,符合题目要求的结果是:31*2=62
    
      现在,请你帮助你的好朋友XZ设计一个程序,求得正确的答案。
    
    输入格式 
    
      程序的输入共有两行:
      第一行共有2个自然数N,K(6≤N≤40,1≤K≤6)
      第二行是一个长度为N的数字串。
    
    
    输出格式 
    
      输出所求得的最大乘积(一个自然数)。
    
      样例输入
    
      4 2
      1231
    样例输出
    62
    */
    #include <stdio.h>
    #define maxN 41
    #define maxK 7
    #define InfiniteMin -999999999
    
    int main()
    {
    	int N,K;
    	int i,j,k,m;
    	int A[maxN][maxK];  /*A[i][j]表示前i个数有j个乘号能达到的最大乘积*/
    	int s[maxN];
    	char num[maxN]; 
    	int temp,max;
    	scanf("%d%d%s",&N,&K,num);
    	for(i=0;i<N;i++)
    		s[i+1]=num[i]-'0';
    	for(i=1;i<=N;i++)
        {
        	temp=0;
        	for(j=1;j<=i;j++)
        	    temp=temp*10+s[j];
        	A[i][0]=temp;
        }
    	for(j=1;j<=K;j++)
    	{
    		for(i=j+1;i<=N;i++)
    		{
    			max=InfiniteMin;
    			for(k=i;k-1>j-1;k--)
    			{
    				temp=0;
    				for(m=k;m<=i;m++)
    					temp=temp*10+s[m]; 
    				temp*=A[k-1][j-1];
    				max=max>temp?max:temp;
    			}
    			A[i][j]=max;
    		}
    	}
        printf("%d",A[N][K]);
    	return 0;
    }
    

     

    /*
    算法训练 方格取数
    
    问题描述 
      设有N*N的方格图(N<=10),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0。
      某人从图的左上角的A 点(1,1)出发,可以向下行走,也可以向右走,直到到达右下角的B点(N,N)。在走过的路上,他可以取走方格中的数(取走后的方格中将变为数字0)。
      此人从A点到B 点共走两次,试找出2条这样的路径,使得取得的数之和为最大。
    输入格式
      输入的第一行为一个整数N(表示N*N的方格图),接下来的每行有三个整数,前两个表示位置,第三个数为该位置上所放的数。一行单独的0表示输入结束。
    输出格式
      只需输出一个整数,表示2条路径上取得的最大的和。
    样例输入
      8
      2 3 13
      2 6 6
      3 5 7
      4 4 14
      5 2 21
      5 6 4
      6 3 15
      7 2 14
      0 0 0
    样例输出
      67
    */
    #include <stdio.h>
    
    #define max(a,b) a>b?a:b
    
    #define min(a,b) a<b?a:b
    
    int main()
    
    {
    
        int map[11][11]={0},f[11][11]={0};
    
        int i,j,k,N,t;
    
        scanf("%d",&N);
    
        while (scanf("%d%d%d",&i,&j,&k)&&(i||j||k)) map[i][j]=k;
    
        for (i=2;i<=2*N;i++)
    
            for (t=min(i,N),j=t;j>0;j--)
    
                for (k=t;k>0;k--)
    
                {
    
                    f[j][k]=max(f[j][k],f[j-1][k-1]);
    
                    f[j][k]=max(f[j][k],f[j][k-1]);
    
                    f[j][k]=max(f[j][k],f[j-1][k]);
    
                    if (j==k) f[j][k]+=map[j][i-j];
    
                    else f[j][k]+=map[j][i-j]+map[k][i-k];
    
                }
    
        printf("%d",f[N][N]);
    
        return 0;
    
    }
    

     

    /*
    算法训练 求先序排列
    
    问题描述
      给出一棵二叉树的中序与后序排列。求出它的先序排列。(约定树结点用不同的大写字母表示,长度<=8)。
    输入格式
      两行,每行一个字符串,分别表示中序和后序排列
    输出格式
      一个字符串,表示所求先序排列
    
      样例输入
      BADC
      BDCA
    样例输出
    ABCD
    */
    #include"stdio.h"
    #include"string.h"
    void dg(char z[],char h[])
    {
        if(strlen(h)==0)
            return;
        printf("%c",h[strlen(h)-1]);
        if(strlen(h)==1)
            return;
        if(strlen(h)==2)
        {
            printf("%c",h[0]);
            return;
       }
        char a[9],b[9];
        int i,j;
       for(i=0;z[i]!=h[strlen(h)-1];i++)
           a[i]=z[i],b[i]=h[i];
        a[i]='\0';
        b[i++]='\0';
        dg(a,b);
        for(j=0;i<strlen(h);i++,j++)
            a[j]=z[i],b[j]=h[i-1];
        a[j]='\0';
        b[j]='\0';
        dg(a,b);
    }
    int main()
    {
        char h[9],z[9];
        scanf("%s",z);
       scanf("%s",h);
       dg(z,h);
        return 0;
    }
    

     

     

     

     

     

    GoToTheNextPart

    展开全文
  • 算法-蓝桥杯习题(2-1)

    万次阅读 多人点赞 2016-01-16 20:23:05
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...

     

    蓝桥杯习题

     

    目录

     

    入门训练(详见 算法-蓝桥杯习题(1-1)Go

     

    基础练习(详见 算法-蓝桥杯习题(2-1)Go

    基础练习(详见 算法-蓝桥杯习题(2-2)Go

    算法训练(详见 算法-蓝桥杯习题(3-1)Go

    算法训练(详见 算法-蓝桥杯习题(3-2)Go

    算法训练(详见 算法-蓝桥杯习题(3-3)Go

    算法训练(详见 算法-蓝桥杯习题(3-4)Go

    算法训练(详见 算法-蓝桥杯习题(3-5)Go

    算法训练(详见 算法-蓝桥杯习题(3-6)Go

    算法提高(详见 算法-蓝桥杯习题(4-1)Go

    算法提高(详见 算法-蓝桥杯习题(4-2)Go

    算法提高(详见 算法-蓝桥杯习题(4-3)Go

     

    历届试题(详见 算法-蓝桥杯习题(5-1)Go

     

    历届试题(详见 算法-蓝桥杯习题(5-2)Go

     

    蓝桥杯练习系统评测数据

    链接: https://pan.baidu.com/s/1brjjmwv
    密码: iieq

     

     

     

    基础训练(PartA-13题)

     

     

     

    /*
    基础练习 闰年判断
    
    问题描述
    给定一个年份,判断这一年是不是闰年。
    
    当以下情况之一满足时,这一年是闰年:
    
    1. 年份是4的倍数而不是100的倍数;
    
    2. 年份是400的倍数。
    
    其他的年份都不是闰年。
    
    输入格式
    输入包含一个整数y,表示当前的年份。
    输出格式
    输出一行,如果给定的年份是闰年,则输出yes,否则输出no。
    说明:当试题指定你输出一个字符串作为结果(比如本题的yes或者no,你需要严格按照试题中给定的大小写,写错大小写将不得分。
    
    样例输入
    2013
    样例输出
    no
    样例输入
    2016
    样例输出
    yes
    数据规模与约定
    1990 <= y <= 2050。
    */
    #include<stdio.h>
    main()
    {
        int y;
        scanf("%d",&y);
    
        if(y%4==0&&y%100!=0||y%400==0)
            printf("yes\n");
        else
            printf("no\n");
            
        return 0;
    }

     

    /*
    基础练习 01字串
    
    问题描述
    对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:
    
    00000
    
    00001
    
    00010
    
    00011
    
    00100
    
    请按从小到大的顺序输出这32种01串。
    
    输入格式
    本试题没有输入。
    输出格式
    输出32行,按从小到大的顺序每行一个长度为5的01串。
    样例输出
    00000
    00001
    00010
    00011
    <以下部分省略>
    */
    #include<stdio.h>
    main()
    {
        int a,b,c,d,e;
        
        for(e=0;e<=1;e++)
        for(d=0;d<=1;d++)
        for(c=0;c<=1;c++)
        for(b=0;b<=1;b++)
        for(a=0;a<=1;a++)
        printf("%d%d%d%d%d\n",e,d,c,b,a);
        
        return 0;
    }

     

    /*
    基础练习 字母图形
    
    问题描述
    利用字母可以组成一些美丽的图形,下面给出了一个例子:
    
    ABCDEFG
    
    BABCDEF
    
    CBABCDE
    
    DCBABCD
    
    EDCBABC
    
    这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。
    
    输入格式
    输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。
    输出格式
    输出n行,每个m个字符,为你的图形。
    样例输入
    5 7
    样例输出
    ABCDEFG
    BABCDEF
    CBABCDE
    DCBABCD
    EDCBABC
    数据规模与约定
    1 <= n, m <= 26。
    */
    #include <stdio.h>
    #include <math.h>
    
    main()
    {
        int n,m,j,k;
        scanf("%d %d",&n,&m);
        if(n>=1&&m<=26)
        for(j=0;j<n;j++)
        {
            for(k=0;k<m;k++)
            printf("%c",65+abs(j-k));
            printf("\n");
        }
        return 0;
    }
    /*
    #include <stdio.h>
    #include <stdlib.h>
    #define MAXSIZE 26
    
    //输出
    void Print(char matrix[MAXSIZE][MAXSIZE],int n,int m)
    {
        int i,j;
        for(i=0;i<n;i++)
        {
            for(j=0;j<m;j++)
            {
                printf("%c",matrix[i][j]);
            }
            printf("\n");
        }
    }
    
    //实现字母图形
    void Drawing(int n,int m)
    {
        int i,j;
        int point=0;
        char str;
        char matrix[MAXSIZE][MAXSIZE];
        for(i=0;i<n;i++)
        {
            str='A';
            for(j=i;j<m;j++)
            {
                matrix[i][j]=str++;
            }
            str='A';
            for(j=i-1;j>=0;j--)
            {
                matrix[i][j]=++str;
            }
        }
        Print(matrix,n,m);
    }
    int main()
    {
        int n,m;
        scanf("%d%d",&n,&m);
        Drawing(n,m);
        return 0;
    }
    */

     

    /*
    基础练习 数列特征
    
    问题描述
    给出n个数,找出这n个数的最大值,最小值,和。
    
    输入格式
    第一行为整数n,表示数的个数。
    
    第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。
    
    输出格式
    输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。
    样例输入
    5
    1 3 -2 4 5
    样例输出
    5
    -2
    11
    数据规模与约定
    1 <= n <= 10000。
    */
    #include <stdio.h>
    #define MaxSize 10000
    
    main()
    {
        int n;
        int sum=0,min=MaxSize,max=-MaxSize;
        
        scanf("%d",&n);
        while(n--)
        {
            int temp,st;
            scanf("%d",&temp);
            
            if(temp>max)
            {
                max=temp;
            }
            if(temp<min)
            {
                min=temp;
            }
            sum+=temp;
        }
        printf("%d\n%d\n%d\n",max,min,sum);
        
        return 0;
    }

     

    /*
    基础练习 查找整数
    
    问题描述
    给出一个包含n个整数的数列,问整数a在数列中的第一次出现是第几个。
    
    输入格式
    第一行包含一个整数n。
    
    第二行包含n个非负整数,为给定的数列,数列中的每个数都不大于10000。
    
    第三行包含一个整数a,为待查找的数。
    
    输出格式
    如果a在数列中出现了,输出它第一次出现的位置(位置从1开始编号),否则输出-1。
    样例输入
    6
    1 9 4 8 3 9
    9
    样例输出
    2
    数据规模与约定
    1 <= n <= 1000。
    */
    #include<stdio.h>
    #define MaxSize 1000+5
    
    main()
    {
        int n,i,a[MaxSize],s,m=0;
        scanf("%d",&n);
    
        for(i=0;i<n;i++)
        {
            scanf("%d ",&a[i]);
        } 
        
        scanf("%d",&s);
        for(i=0;i<n;i++)
        {
            if(s==a[i])
            {
                printf("%d\n",i+1);
                return 0;
            }
        }
        
        printf("-1\n");
    
        return 0;    
    }

     

     

    /*
    基础练习 杨辉三角形
    
    问题描述
    杨辉三角形又称Pascal三角形,它的第i+1行是(a+b)i的展开式的系数。
    
      
    它的一个重要性质是:三角形中的每个数字等于它两肩上的数字相加。
    
      
    下面给出了杨辉三角形的前4行:
    
      
       1
    
      
      1 1
    
      
     1 2 1
    
      
    1 3 3 1
    
      
    给出n,输出它的前n行。
    
    输入格式
    输入包含一个数n。
    
    输出格式
    输出杨辉三角形的前n行。每一行从这一行的第一个数开始依次输出,中间使用一个空格分隔。请不要在前面输出多余的空格。
    样例输入
    4
    样例输出
    1
    1 1
    1 2 1
    1 3 3 1
    数据规模与约定
    1 <= n <= 34。
    */
    #include<stdio.h>
    main()
    {
    	int n,x,y,a[35][35]={0};
    	int i,j;
    	scanf("%d",&n);
    	if(n>=1&&n<=34)
    	//赋值对角线元素为1 
    	{
    		for(x=1;x<=n;x++)
    		{
    			a[x][1]=1;
    			a[x][x]=1;
    		}
    		//赋值其他元素 
    		for(x=3;x<=n;x++)
    		for(y=2;y<=n;y++)
    		a[x][y]=a[x-1][y]+a[x-1][y-1];
    		//输出对应元素 
    		for(j=1,x=1;x<=n;x++)
    		{
    			for(y=1;y<=j;y++)
    			{
    				printf("%d ",a[x][y]);
    			}
    			j++;
    			printf("\n");
    		}
    	}
    	return 0;
    }
    

     

    /*
    基础练习 特殊的数字
    
    问题描述
      153是一个非常特殊的数,它等于它的每位数字的立方和,即153=1*1*1+5*5*5+3*3*3。编程求所有满足这种条件的三位十进制数。
    输出格式
      按从小到大的顺序输出满足条件的三位十进制数,每个数占一行。
    */
    #include<stdio.h>
    
    main()
    {
    	int i,j,k;
    	int n;
    	
    	for(i=1;i<=9;i++)
    	for(j=0;j<=9;j++)
    	for(k=0;k<=9;k++)
    	{
    		if(i*100+j*10+k==i*i*i+j*j*j+k*k*k)
    		printf("%d%d%d\n",i,j,k);
    	}
    	return 0;
    }
    

     

     

     

     

    /*
    基础练习 回文数
    
    问题描述
      1221是一个非常特殊的数,它从左边读和从右边读是一样的,编程求所有这样的四位十进制数。
    输出格式
      按从小到大的顺序输出满足条件的四位十进制数。
    */
    #include<stdio.h>
    main()
    {
        int a,b,i;
        for(a=1;a<=9;a++)
        for(b=0;b<=9;b++)
        {
            printf("%d%d%d%d\n",a,b,b,a);
        }
        return 0;
    }
    
    /*
    #include<stdio.h>
    int main()
    {
     int a,b,c,d,i;
     for(i=1000;i<=9999;i++)
     {  
       a=i/1000;
       b=i/100%10;
       c=i/10%10;
       d=i%10;
      if(a==d&&b==c)
        printf("%d\n",i);
     }
    return 0;
    }
    */

     

    /*
    基础练习 特殊回文数
    
    问题描述
      123321是一个非常特殊的数,它从左边读和从右边读是一样的。
      输入一个正整数n, 编程求所有这样的五位和六位十进制数,满足各位数字之和等于n 。
    输入格式
      输入一行,包含一个正整数n。
    输出格式
      按从小到大的顺序输出满足条件的整数,每个整数占一行。
    样例输入
    52
    样例输出
    899998
    989989
    998899
    数据规模和约定
      1<=n<=54。
    */
    #include<stdio.h>
    main()
    {
        int n,a,b,c;
        scanf("%d",&n);
    
        for(a=1;a<=9;a++)
        for(b=0;b<=9;b++)
        for(c=0;c<=9;c++)
        {
            if(n==2*a+2*b+c)
            printf("%d%d%d%d%d\n",a,b,c,b,a);
        }
        for(a=1;a<=9;a++)
        for(b=0;b<=9;b++)
        for(c=0;c<=9;c++)
        {
            if(n==2*a+2*b+2*c)
            printf("%d%d%d%d%d%d\n",a,b,c,c,b,a);
        }
    
        return 0;
    }
    /*
    #include<stdio.h>
    int main()
    {
        int a,b,c,d,e,f,t,all;
        scanf("%d",&t);
        for(a=1;a<10;a++)
            for(b=0;b<10;b++)
                for(c=0;c<10;c++)
                    for(d=0;d<10;d++)
                        for(e=0;e<10;e++)
                        {
                            if(a==e)
                                if(b==d)
                                    {
                                        all=a+b+c+d+e;
                                        if(all==t)
                                        printf("%d\n",a*10000+b*1000+c*100+d*10+e);
                                    }
                        }
        for(a=1;a<10;a++)
            for(b=0;b<10;b++)
                for(c=0;c<10;c++)
                    for(d=0;d<10;d++)
                        for(e=0;e<10;e++)
                            for(f=0;f<10;f++)
                            {
                                if(a==f)
                                    if(b==e)
                                        if(c==d)
                                        {
                                            all=a+b+c+d+e+f;
                                            if(all==t)
                                                printf("%d\n",a*100000+b*10000+c*1000+d*100+e*10+f);
                                        }
                            }
                        
        return 0;
    }
    
    */

     

     

    /*
    基础练习 十进制转十六进制
    
    问题描述
      十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15。十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E。
      给出一个非负整数,将它表示成十六进制的形式。
    输入格式
      输入包含一个非负整数a,表示要转换的数。0<=a<=2147483647
    输出格式
      输出这个整数的16进制表示
    样例输入
    30
    样例输出
    1E
    */
    #include<stdio.h>
    main()
    {
    	int a;
    	scanf("%d",&a);
    	if(0<=a&&a<=2147483647)
    	printf("%X",a);
    	return 0;
    }
    /*
    #include <stdio.h>
    #include <stdlib.h>
    char data[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
    
    //输出
    void Print(char *num,int n)
    {
    	int i;
    	for(i=n-1;i>=0;i--) printf("%c",num[i]);
    	printf("\0");
    	printf("\n");
    }
    
    //将十六进制数转换为十进制数
    int Transform(char *num,long long value)
    {
    	int n=0;
    	while(value>=16)
    	{
    		num[n++]=data[value%16];
    		value/=16;
    	}
    	num[n++]=data[value%16];
    	return n;
    }
    
    int main()
    {
    	long long value;
    	char num[10];
    	int n;
    	scanf("%I64d",&value);
    	n=Transform(num,value);
    	Print(num,n);
    	return 0;
    }
    */
    

     

     

     

     

     

     

    /*
    基础练习 十六进制转十进制
    
    问题描述
      从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
      注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
    样例输入
    FFFF
    样例输出
    65535
    */
    #include<stdio.h>
    #include<string.h>
    
    int main()
    {
        char a[9];
        int i;
        unsigned int n=1,b=0;
        scanf("%s",a);
        
        for(i=strlen(a)-1;i>=0;i--)
        {
            if(a[i]<='9')
            b+=(a[i]-'0')*n;
            else
            b+=(a[i]-'A'+10)*n;
            n=16*n;
        }
        printf("%u\n",b);
        return 0;
    }
    /*
    #include<stdio.h>
    #include<string.h> 
    #include<math.h>
    int main()
    { 
     double sum=0,x;
     char a[8];
     int len,i=0;
     gets(a);
     len=strlen(a);
     while(len)
     {
      if(a[len-1]>='A'&&a[len-1]<='F')
        x=(a[len-1]-'7')*pow(16,i++);
      else
          x=(a[len-1]-'0')*pow(16,i++);
      sum+=x;
      len--;
     }
     printf("%.0lf",sum);
    
     return 0;
     
     }
    */

     

    /*
    基础练习 十六进制转八进制
    
    问题描述
      给定n个十六进制正整数,输出它们对应的八进制数。
    输入格式
      输入的第一行为一个正整数n (1<=n<=10)。
      接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
    输出格式
      输出n行,每行为输入对应的八进制正整数。
    注意
      输入的十六进制数不会有前导0,比如012A。
      输出的八进制数也不能有前导0。
    样例输入
    2
    39
    123ABC
    样例输出
    71
    4435274
    提示
      先将十六进制数转换成某进制数,再由某进制数转换成八进制。
    */
    #include <cstdio>
    #include <iostream>
    #include <cstring>
    #include <string>
    #include <cmath>
    #include <algorithm>
    #include <set>
    using namespace std;
    char str[100005], num;
    void Fun(int i, int state)
    {
    int temp;
    if(i < 0)
    {
    if(num != 0)
    {
    printf("%d", num);
    }
    return;
    }
    if(state != 3)
    {
    temp = str[i] >= '0' && str[i] <= '9' ? str[i] - '0' : str[i] - 'A' + 10;
    temp <<= state;
    num |= temp;
    temp = num;
    num >>= 3;
    Fun(i - 1, state + 1);
    printf("%d", (temp & 1) + (temp & 2) + (temp & 4));
    }
    else
    {
    temp = num;
    num >>= 3;
    Fun(i, 0);
    printf("%d", (temp & 1) + (temp & 2) + (temp & 4));
    }
    }
    int main()
    {
    int n;
    scanf("%d", &n);
    while(n--)
    {
    num = 0;
    scanf("%s", str);
    Fun(strlen(str) - 1, 0);
    printf("\n");
    }
    return 0;
    }
    /*
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    
    #define MaxSize 100000
    
    void saveB(char *b,char c3,char c2,char c1,char c0,int start)
    {
        b[start]=c3;
        b[start+1]=c2;
        b[start+2]=c1;
        b[start+3]=c0;
    }
    int htob(char *h,char *b)
    {
        int i,j;
        int hl=strlen(h);
        for(i=0;i<hl;i++)
            switch(h[i])
            {
                case '0':
                    {
                        saveB(b,'0','0','0','0',4*i);
                        break;
                    }
                case '1':
                    {
                        saveB(b,'0','0','0','1',4*i);
                        break;
                    }
                case '2':
                    {
                        saveB(b,'0','0','1','0',4*i);
                        break;
                    }
                case '3':
                    {
                        saveB(b,'0','0','1','1',4*i);
                        break;
                    }
                case '4':
                    {
                        saveB(b,'0','1','0','0',4*i);
                        break;
                    }
                case '5':
                    {
                        saveB(b,'0','1','0','1',4*i);
                        break;
                    }
                case '6':
                    {
                        saveB(b,'0','1','1','0',4*i);
                        break;
                    }
                case '7':
                    {
                        saveB(b,'0','1','1','1',4*i);
                        break;
                    }
                case '8':
                    {
                        saveB(b,'1','0','0','0',4*i);
                        break;
                    }
                case '9':
                    {
                        saveB(b,'1','0','0','1',4*i);
                        break;
                    }
                case 'A':
                    {
                        saveB(b,'1','0','1','0',4*i);
                        break;
                    }
                case 'B':
                    {
                        saveB(b,'1','0','1','1',4*i);
                        break;
                    }
                case 'C':
                    {
                        saveB(b,'1','1','0','0',4*i);
                        break;
                    }
                case 'D':
                    {
                        saveB(b,'1','1','0','1',4*i);
                        break;
                    }
                case 'E':
                    {
                        saveB(b,'1','1','1','0',4*i);
                        break;
                    }
                case 'F':
                    {
                        saveB(b,'1','1','1','1',4*i);
                        break;
                    }
            }
        return 4*hl;
    }
    int btoo(char *b,char *o,int bl)
    {
        int i,j;
        int ol;
        int value;
        if(bl%3==0)
            ol=bl/3;
        else
            ol=bl/3+1;
        j=bl-1;
        for(i=ol-1;i>=0;i--)
        {
            if(i>0)
                o[i]=b[j]-48+(b[j-1]-48)*2+(b[j-2]-48)*4+48;
            else
            {
                switch(j)
                {
                    case 2:
                        o[i]=b[j]-48+(b[j-1]-48)*2+(b[j-2]-48)*4+48;
                        break;
                    case 1:
                        o[i]=b[j]-48+(b[j-1]-48)*2+48;
                        break;
                    case 0:
                        o[i]=b[j];
                        break;
                }
    
            }
            j=j-3;
        }
        return ol;
    }
    void printO(char *o,int ol)
    {
        int i=0;
        if(o[0]=='0')
            i=1;
        for(;i<ol;i++)
        {
            printf("%c",o[i]);
        }
        printf("\n");
    }
    main()
    {
        char h[MaxSize];
        char b[4*MaxSize];
        char o[4*MaxSize/3+1];
        int n,i,bl,ol;
        scanf("%d",&n);
        getchar();
        for(i=0;i<n;i++)
        {
            gets(h);
            bl=htob(h,b);
            ol=btoo(b,o,bl);
            
            printO(o,ol);
        }
    }
    
    */

     

    /*
    基础练习 数列排序
    
    问题描述
      给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
    输入格式
      第一行为一个整数n。
      第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
    输出格式
      输出一行,按从小到大的顺序输出排序后的数列。
    样例输入
    5
    8 3 6 4 9
    样例输出
    3 4 6 8 9
    */
    #include <stdio.h>
    
    int main()
    {
        int n,i,j,s,a[200];
        
        scanf("%d",&n);
    
        for(i=1;i<=n;i++)
        {
            scanf("%d",&a[i]);
        }
        
        i=n+1;
         
        while(i--)
        for(j=1;j<i;j++)
        {
            if(a[j]>a[j+1])
            {
                s=a[j+1];
                a[j+1]=a[j];
                a[j]=s;
            }
        }
        
        for(i=1;i<=n;i++)
        printf("%d ",a[i]);
        
        return 0;
    }
    /*
    #include <stdio.h>
    #include <stdlib.h>
    void Print(int *data,int n)
    {
        int i;
        for(i=0;i<n;i++)
        {
            printf("%d ",data[i]);
        }
        printf("\n");
    }
    
    int Split(int *data,int pre,int rear)
    {
        int value=data[pre];
        while(pre<rear)
        {
            while(data[rear]>=value && pre<rear) rear--;
            data[pre]=data[rear];
            while(data[pre]<value && pre<rear) pre++;
            data[rear]=data[pre];
        }
        data[pre]=value;
        return pre;
    }
    
    //快速排序
    void QuickSort(int *data,int pre,int rear)
    {
        if(pre<rear)
        {
            int mid=Split(data,pre,rear);
            QuickSort(data,pre,mid-1);
            QuickSort(data,mid+1,rear);
        }
    }
    
    int main()
    {
        int i;
        int n;
        int *data;
        scanf("%d",&n);
        data=(int *)malloc(sizeof(int)*n);
        for(i=0;i<n;i++)
        {
            scanf("%d",&data[i]);
        }
        QuickSort(data,0,n-1);
        Print(data,n);
        return 0;
    }
    */

     

    GoToNextPart

     

     

    展开全文
  • 算法-蓝桥杯习题(2-2)

    万次阅读 多人点赞 2016-01-16 20:33:59
    蓝桥杯习题 目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1))Go ...

     

    蓝桥杯习题

    目录

     

    入门训练(详见 算法-蓝桥杯习题(1-1))Go

     

    基础练习(详见 算法-蓝桥杯习题(2-1))Go

    基础练习(详见 算法-蓝桥杯习题(2-2))Go

    算法训练(详见 算法-蓝桥杯习题(3-1))Go

    算法训练(详见 算法-蓝桥杯习题(3-2))Go

    算法训练(详见 算法-蓝桥杯习题(3-3))Go

    算法训练(详见 算法-蓝桥杯习题(3-4))Go

    算法训练(详见 算法-蓝桥杯习题(3-5))Go

    算法训练(详见 算法-蓝桥杯习题(3-6))Go

    算法提高(详见 算法-蓝桥杯习题(4-1))Go

     

    历届试题(详见 算法-蓝桥杯习题(5-1))Go

     

    历届试题(详见 算法-蓝桥杯习题(5-2))Go

     

     

    蓝桥杯练习系统评测数据

     

    链接: http://pan.baidu.com/s/1mhophTQ
    密码: m2pa

     

     

    基础训练(PartB-17题)

     

     

     

    /*
    基础练习 时间转换
    
    问题描述
      给定一个以秒为单位的时间t,要求用“<H>:<M>:<S>”的格式来表示这个时间。<H>表示时间,<M>表示分钟,而<S>表示秒,它们都是整数且没有前导的“0”。例如,若t=0,则应输出是“0:0:0”;若t=3661,则输出“1:1:1”。
    输入格式
      输入只有一行,是一个整数t(0<=t<=86399)。
    输出格式
      输出只有一行,是以“<H>:<M>:<S>”的格式所表示的时间,不包括引号。
    样例输入
    0
    样例输出
    0:0:0
    样例输入
    5436
    样例输出
    1:30:36
    */
    #include<stdio.h>
     
     int main()
    {
      int a,b,c,d;
      scanf("%d",&a);
    
      b=(int)(a/3600);
      c=(int)(a%3600)/60;
      d=(int)((a%3600)%60);
      printf("%d:%d:%d",b,c,d);
      return 0;
      
    }

     

    /*
    基础练习 字符串对比
    
    问题描述
      给定两个仅由大写字母或小写字母组成的字符串(长度介于1到10之间),它们之间的关
    
    系是以下4中情况之一:
      1:两个字符串长度不等。比如 Beijing 和 Hebei
      2:两个字符串不仅长度相等,而且相应位置上的字符完全一致(区分大小写),比如 
    
    Beijing 和 Beijing
      3:两个字符串长度相等,相应位置上的字符仅在不区分大小写的前提下才能达到完
    
    全一致(也就是说,它并不满足情况2)。比如 beijing 和 BEIjing
      4:两个字符串长度相等,但是即使是不区分大小写也不能使这两个字符串一致。比
    
    如 Beijing 和 Nanjing
      编程判断输入的两个字符串之间的关系属于这四类中的哪一类,给出所属的类的编号
    
    。
    输入格式
      包括两行,每行都是一个字符串
    输出格式
      仅有一个数字,表明这两个字符串的关系编号
    样例输入
    BEIjing
    beiJing
    样例输出
    3
    */
    #include<stdio.h>
    #include<string.h>
    int main()
    {
        char a[10],b[10],i,n,l=2;
        gets(a);gets(b);
        n=strlen(a);
        if(strlen(b)!=n)l=1;
        else
        {
        for(i=0;i<n;i++)
        if(a[i]==b[i]||a[i]==b[i]+32||a[i]+32==b[i])
            if(a[i]!=b[i])l=3;
            else ;else {l=4;break;}
        }
    printf("%d",l);
    return 0;
    }

     

    /*
    基础练习 分解质因数
    
    问题描述
      求出区间[a,b]中所有整数的质因数分解。
    输入格式
      输入两个整数a,b。
    输出格式
      每行输出一个数的分解,形如k=a1*a2*a3...(a1<=a2<=a3...,k也是从小到大的)(具体可看样例)
    样例输入
    3 10
    样例输出
    3=3
    4=2*2
    5=5
    6=2*3
    7=7
    8=2*2*2
    9=3*3
    10=2*5
    提示
      先筛出所有素数,然后再分解。
    数据规模和约定
      2<=a<=b<=10000
    */
    #include<stdio.h>
    #include<math.h>
    int main()
    {
        long int b,i,k,m,n,w = 0;
        scanf("%ld%ld",&m,&n);
        for(i = m;i<=n;i++)
        {
            printf("%ld=",i);
            b = i;k = 2;
            while(k<=sqrt(i))
            {
                if(b%k==0)
                {
                    b = b/k;
                    if(b>1)
                    {
                        printf("%ld*",k);continue;
                    }   
                    if(b==1) printf("%ld\n",k);
                }
                k++;
            }
            if(b>1&&b<i) printf("%ld\n",b);
            if(b==i)
            {
                printf("%d\n",i);w++;
            }     
        }
        return 0;
    }

     

    /*
    基础练习 矩阵乘法
    
    问题描述
      给定一个N阶矩阵A,输出A的M次幂(M是非负整数)
      例如:
      A =
      1 2
      3 4
      A的2次幂
      7 10
      15 22
    输入格式
      第一行是一个正整数N、M(1<=N<=30, 0<=M<=5),表示矩阵A的阶数和要求的幂
    
    数
      接下来N行,每行N个绝对值不超过10的非负整数,描述矩阵A的值
    输出格式
      输出共N行,每行N个整数,表示A的M次幂所对应的矩阵。相邻的数之间用一个空格
    
    隔开
    样例输入
    2 2
    1 2
    3 4
    样例输出
    7 10
    15 22
    */
    #include <stdio.h>
    #include <string.h>
    #define N 100
    int A[N][N],t[N][N],r[N][N];
    int main()
    {
        int n,m,i,j,k;
        scanf("%d%d",&n,&m);
        for(i=0;i<n;i++)
            for(j=0;j<n;j++)
                scanf("%d",&A[i][j]);
        for(i=0;i<n;i++) 
             r[i][i]=1;//单位矩阵,如同数的乘法中的1
        while(m--)
        {
            memset(t,0,sizeof(t));
            for(i=0;i<n;i++)
                for(j=0;j<n;j++)
                    for(k=0;k<n;k++)
                        t[i][j]+=r[i][k]*A[k][j];
            for(i=0;i<n;i++)
                for(j=0;j<n;j++)
                     r[i][j]=t[i][j];
        }
        for(i=0;i<n;i++)
        {
            for(j=0;j<n-1;j++)
                printf("%d ",r[i][j]);    
            printf("%d\n",r[i][j]);    
        }
        return 0;
    }

     

    /*
    基础练习 矩形面积交
    
    问题描述
      平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴。对于每个矩形,我们
    
    给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积。
    输入格式
      输入仅包含两行,每行描述一个矩形。
      在每行中,给出矩形的一对相对顶点的坐标,每个点的坐标都用两个绝对值不超过
    
    10^7的实数表示。
    输出格式
      输出仅包含一个实数,为交的面积,保留到小数后两位。
    样例输入
    1 1 3 3
    2 2 4 4
    样例输出
    1.00
    */
    #include <stdio.h>
    #define max(x,y) ((x)>(y)?(x):(y))
    #define min(x,y) ((x)<(y)?(x):(y))
    int main()
    {
        double x1,y1,x2,y2;//矩形1 
        double x3,y3,x4,y4;//矩形2    
        double m1,n1;//交集左上角坐标 
        double m2,n2;//交集右下角坐标 
        scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
        scanf("%lf%lf%lf%lf",&x3,&y3,&x4,&y4);
        m1=max(min(x1,x2),min(x3,x4));
        n1=max(min(y1,y2),min(y3,y4));
        m2=min(max(x1,x2),max(x3,x4));
        n2=min(max(y1,y2),max(y3,y4));
        if(m2>m1&&n2>n1)  
            printf("%.2f\n",(m2-m1)*(n2-n1));    
        else 
            printf("0.00\n");
        return 0;
    }

     

    /*
    基础练习 完美的代价
    
    问题描述
      回文串,是一种特殊的字符串,它从左往右读和从右往左读是一样的。小龙龙认为回
    
    文串才是完美的。现在给你一个串,它不一定是回文的,请你计算最少的交换次数使得该
    
    串变成一个完美的回文串。
      交换的定义是:交换两个相邻的字符
      例如mamad
      第一次交换 ad : mamda
      第二次交换 md : madma
      第三次交换 ma : madam (回文!完美!)
    输入格式
      第一行是一个整数N,表示接下来的字符串的长度(N <= 8000)
      第二行是一个字符串,长度为N.只包含小写字母
    输出格式
      如果可能,输出最少的交换次数。
      否则输出Impossible
    样例输入
    5
    mamad
    样例输出
    3
    */
    #include<stdio.h>  
    int changes(char s[],char x,int n); 
    char x='0'; 
    int main(void) 
    { 
       int n,i,k=0,b[26]={0},j; 
       char y,s[8000]={0}; 
       scanf("%d",&n); 
       getchar(); 
       for(i=0;i<n;i++) 
       scanf("%c",&s[i]); 
       for(i=0;i<n;i++)
       { 
           j=s[i]-'a'; 
           b[j]++; 
       } 
       for(j=0;j<26;j++)
       { 
           if(b[j]%2!=0)
           { 
               k++; 
               x=j+'a';
               
          } 
       } 
       if(k>=2) 
       printf("Impossible\n"); 
       else 
       printf("%d\n",changes(s,x,n)); 
       return 0; 
    }  
    
    int changes(char s[],char x,int n) 
    { 
        int i,change=0,j,k; 
        for(i=0;i<n/2;i++)
        { 
           if(s[i]==x)
           { 
             for(j=i;j<n-i-1;j++) 
             if(s[n-i-1]==s[j]) 
             break; 
             change+=j-i; 
             for(k=j;k>i;k--) 
             s[k]=s[k-1]; 
             s[i]=s[n-i-1]; 
           }
           else 
           { 
           for(j=n-i-1;j>=i;j--) 
           if(s[i]==s[j]) 
           break; 
           change+=n-i-1-j; 
           for(k=j;k<n-i-1;k++) 
           s[k]=s[k+1]; 
           s[n-i-1]=s[i]; 
           }
        }  
        return change; 
    }

     

    /*
    基础练习 数的读法
    
    问题描述
      Tom教授正在给研究生讲授一门关于基因的课程,有一件事情让他颇为头疼:一条染
    
    色体上有成千上万个碱基对,它们从0开始编号,到几百万,几千万,甚至上亿。
      比如说,在对学生讲解第1234567009号位置上的碱基时,光看着数字是很难准确的念
    
    出来的。
      所以,他迫切地需要一个系统,然后当他输入12 3456 7009时,会给出相应的念法:
      十二亿三千四百五十六万七千零九
      用汉语拼音表示为
      shi er yi san qian si bai wu shi liu wan qi qian ling jiu
      这样他只需要照着念就可以了。
      你的任务是帮他设计这样一个系统:给定一个阿拉伯数字串,你帮他按照中文读写的
    
    规范转为汉语拼音字串,相邻的两个音节用一个空格符格开。
      注意必须严格按照规范,比如说“10010”读作“yi wan ling yi shi”而不是“yi wan 
    
    ling shi”,“100000”读作“shi wan”而不是“yi shi wan”,“2000”读作“er qian”而
    
    不是“liang qian”。
    输入格式
      有一个数字串,数值大小不超过2,000,000,000。
    输出格式
      是一个由小写英文字母,逗号和空格组成的字符串,表示该数的英文读法。
    样例输入
    1234567009
    样例输出
    shi er yi san qian si bai wu shi liu wan qi qian ling jiu
    */
    #include<stdio.h>
    #include<string.h>
    int main()
    {
        char a[100];int i,j,k,l;
        char b[20][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
        char c[20][10]={"","","shi","bai","qian","wan","shi","bai","qian","yi","shi"};
        gets(a);
        l=strlen(a);
        for(i=0;i<l;i++){
            j=a[i]-48;
            if(j==0){if(i<l-1)if(a[i+1]!=48)printf("%s ",b[j]);}
            else 
            if((l-i==2||l-i==6||l-i==10)&&j==1)printf("%s ",c[l-i]);
            else if(a[i-1]==48&&j==1)printf("%s ",c[l-i]);
            else printf("%s %s ",b[j],c[l-i]);
        }
        printf("\n");
        return 0;
    }

     

    /*
    基础练习 Sine之舞
    
    问题描述
      最近FJ为他的奶牛们开设了数学分析课,FJ知道若要学好这门课,必须有一个好的三
    
    角函数基本功。所以他准备和奶牛们做一个“Sine之舞”的游戏,寓教于乐,提高奶牛们
    
    的计算能力。
      不妨设
      An=sin(1–sin(2+sin(3–sin(4+...sin(n))...)
      Sn=(...(A1+n)A2+n-1)A3+...+2)An+1
      FJ想让奶牛们计算Sn的值,请你帮助FJ打印出Sn的完整表达式,以方便奶牛们做题。
    输入格式
      仅有一个数:N<201。
    输出格式
      请输出相应的表达式Sn,以一个换行符结束。输出中不得含有多余的空格或换行、回
    
    车符。
    样例输入
    3
    样例输出
    ((sin(1)+3)sin(1–sin(2))+2)sin(1–sin(2+sin(3)))+1
    */
    #include <stdio.h>
    
    void printA(int n, int k)
    {
        if (n == k)
            printf("sin(%d)", n);
        else
        {
            printf("sin(%d", n);
            printf(n % 2 == 0 ? "+" : "-");
            printA(n + 1, k);
            printf(")");
        }
    }
    
    void printS(int n, int k)
    {
        if (n == 1)
        {
            printA(1, n);
            printf("+%d", k - n);
        }
        else
        {
            printf("(");
            printS(n - 1, k);
            printf(")");
            printA(1, n);
            printf("+%d", k - n);
        }
    }
    
    int main()
    {
        int N;
        scanf("%d", &N);
        printS(N, N + 1);
        printf("\n");
        return 0;
    }

     

    /*
    基础练习 FJ的字符串
    
    问题描述
      FJ在沙盘上写了这样一些字符串:
      A1 = “A”
      A2 = “ABA”
      A3 = “ABACABA”
      A4 = “ABACABADABACABA”
      … …
      你能找出其中的规律并写所有的数列AN吗?
    输入格式
      仅有一个数:N ≤ 26。
    输出格式
      请输出相应的字符串AN,以一个换行符结束。输出中不得含有多余的空格或换行、
    
    回车符。
    样例输入
    3
    样例输出
    ABACABA
    */
    #include<stdio.h>
    void f(int a)
    {
        if(a==0)printf("%c",'A');
        else 
        {
            f(a-1);
            printf("%c",a+'A');
            f(a-1);
        }
    }
    int main()
    {
        int a;scanf("%d",&a);f(a-1);printf("\n");
        return 0;
    }

     

    /*
    基础练习 芯片测试
    
    问题描述
      有n(2≤n≤20)块芯片,有好有坏,已知好芯片比坏芯片多。
      每个芯片都能用来测试其他芯片。用好芯片测试其他芯片时,能正确给出被测试芯片
    
    是好还是坏。而用坏芯片测试其他芯片时,会随机给出好或是坏的测试结果(即此结果与
    
    被测试芯片实际的好坏无关)。
      给出所有芯片的测试结果,问哪些芯片是好芯片。
    输入格式
      输入数据第一行为一个整数n,表示芯片个数。
      第二行到第n+1行为n*n的一张表,每行n个数据。表中的每个数据为0或1,在这n行
    
    中的第i行第j列(1≤i, j≤n)的数据表示用第i块芯片测试第j块芯片时得到的测试结果,1
    
    表示好,0表示坏,i=j时一律为1(并不表示该芯片对本身的测试结果。芯片不能对本身
    
    进行测试)。
    输出格式
      按从小到大的顺序输出所有好芯片的编号
    样例输入
    3
    1 0 1
    0 1 0
    1 0 1
    样例输出
    1 3
    */
    #include<stdio.h>
    #include<string.h>
    int main()
    {
        int a[50][50];int i,j,n,s;scanf("%d",&n);
         for(j=0;j<n;j++)for(i=0;i<n;i++)scanf("%d",&a[i][j]);
        for(j=0;j<n;j++){s=0;for(i=0;i<n;i++)s=s+a[j][i];if(s>n/2.0)printf("%d ",j+1);}
        return 0;
    }

     

    /*
    基础练习 龟兔赛跑预测
    
    问题描述
      话说这个世界上有各种各样的兔子和乌龟,但是研究发现,所有的兔子和乌龟都有一个共同的特点——喜欢赛跑。于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研究不同兔子和乌龟的赛跑。他发现,兔子虽然跑比乌龟快,但它们有众所周知的毛病——骄傲且懒惰,于是在与乌龟的比赛中,一旦任一秒结束后兔子发现自己领先t米或以上,它们就会停下来休息s秒。对于不同的兔子,t,s的数值是不同的,但是所有的乌龟却是一致——它们不到终点决不停止。
      然而有些比赛相当漫长,全程观看会耗费大量时间,而小华发现只要在每场比赛开始后记录下兔子和乌龟的数据——兔子的速度v1(表示每秒兔子能跑v1米),乌龟的速度v2,以及兔子对应的t,s值,以及赛道的长度l——就能预测出比赛的结果。但是小华很懒,不想通过手工计算推测出比赛的结果,于是他找到了你——清华大学计算机系的高才生——请求帮助,请你写一个程序,对于输入的一场比赛的数据v1,v2,t,s,l,预测该场比赛的结果。
    输入格式
      输入只有一行,包含用空格隔开的五个正整数v1,v2,t,s,l,其中(v1,v2<=100;t<=300;s<=10;l<=10000且为v1,v2的公倍数)
    输出格式
      输出包含两行,第一行输出比赛结果——一个大写字母“T”或“R”或“D”,分别表示乌龟获胜,兔子获胜,或者两者同时到达终点。
      第二行输出一个正整数,表示获胜者(或者双方同时)到达终点所耗费的时间(秒数)。
    样例输入
    10 5 5 2 20
    样例输出
    D
    4
    样例输入
    10 5 5 1 20
    样例输出
    R
    3
    样例输入
    10 5 5 3 20
    样例输出
    T
    4 
    */
    #include<stdio.h>
    int main()
    {
        int v1,v2,t,s,l,s1=0,s2=0,i=0;
        scanf("%d %d %d %d %d",&v1,&v2,&t,&s,&l);
        while(s1<l&&s2<l)
        {
            s1+=v1;
            s2+=v2;
            i++;
            if(s1==l||s2==l)break;
            if(s1-s2>=t)s1-=v1*s;
        }
        if(s1>s2)      printf("R\n");
        else if(s2>s1) printf("T\n");
        else           printf("D\n");
        printf("%d",i);
        return 0;
    }

     

    /*
    基础练习 回形取数  
    
    问题描述
      回形取数就是沿矩阵的边取数,若当前方向上无数可取或已经取过,则左转90度。一开始位于矩阵左上角,方向向下。
    输入格式
      输入第一行是两个不超过200的正整数m, n,表示矩阵的行和列。接下来m行每行n个整数,表示这个矩阵。
    输出格式
      输出只有一行,共mn个数,为输入矩阵回形取数得到的结果。数之间用一个空格分隔,行末不要有多余的空格。
    样例输入
    3 3
    1 2 3
    4 5 6
    7 8 9
    样例输出
    1 4 7 8 9 6 3 2 5
    样例输入
    3 2
    1 2
    3 4
    5 6
    样例输出
    1 3 5 6 4 2
    */
    #include <stdio.h>
    #include <string.h>
    
    #define MAX_N 200
    int m,n;
    int a[MAX_N][MAX_N],b[MAX_N][MAX_N];
    int s=0;
    void solve(int i,int j)
    {
        if(i<m && i>=0 && j<n && j>=0 && b[i][j] == 0)
        {
            printf("%d ",a[i][j]);
            b[i][j] = 1;
        
        }
        else
        {
            s++;
            return ;
        }
        if(s%4 == 0)
        solve(i+1,j);
        if(s%4 == 1)
        solve(i,j+1);
        if(s%4 == 2)
        solve(i-1,j);
        if(s%4 == 3)
        solve(i,j-1);
        if(s%4 == 0)
        solve(i+1,j);
        if(s%4 == 1)
        solve(i,j+1);
        if(s%4 == 2)
        solve(i-1,j);
        if(s%4 == 3)
        solve(i,j-1);
    
        return ;
    }
    
    int main()
    {
        memset(b,0,sizeof(b));
        scanf("%d%d",&m,&n);
        int i,j;
        for(i=0; i<m; i++)
            for(j=0; j<n; j++)
                scanf("%d",&a[i][j]);
        solve(0,0);
        puts("");
        return 0;
    }

     

    /*
    基础练习 报时助手
    
    问题描述
      给定当前的时间,请用英文的读法将它读出来。
      时间用时h和分m表示,在英文的读法中,读一个时间的方法是:
      如果m为0,则将时读出来,然后加上“o'clock”,如3:00读作“three o'clock”。
      如果m不为0,则将时读出来,然后将分读出来,如5:30读作“five thirty”。
      时和分的读法使用的是英文数字的读法,其中0~20读作:
      0:zero, 1: one, 2:two, 3:three, 4:four, 5:five, 6:six, 7:seven, 8:eight, 9:nine, 10:ten, 11:eleven, 12:twelve, 13:thirteen, 14:fourteen, 15:fifteen, 16:sixteen, 17:seventeen, 18:eighteen, 19:nineteen, 20:twenty。
      30读作thirty,40读作forty,50读作fifty。
      对于大于20小于60的数字,首先读整十的数,然后再加上个位数。如31首先读30再加1的读法,读作“thirty one”。
      按上面的规则21:54读作“twenty one fifty four”,9:07读作“nine seven”,0:15读作“zero fifteen”。
    输入格式
      输入包含两个非负整数h和m,表示时间的时和分。非零的数字前没有前导0。h小于24,m小于60。
    输出格式
      输出时间时刻的英文。
    样例输入
    0 15
    样例输出
    zero fifteen
    */
    #include <stdio.h>
    
    void printTime(int n)
    {
    	switch(n)
    	{
    		case 0: printf("zero"); break;
    		case 1: printf("one") ; break;
    		case 2: printf("two"); break;
    		case 3: printf("three"); break;
    		case 4: printf("four"); break;
    		case 5: printf("five"); break;
    		case 6: printf("six"); break;
    		case 7: printf("seven"); break;
    		case 8: printf("eight"); break;
    		case 9: printf("nine"); break;
    		case 10: printf("ten"); break;
    		case 11: printf("eleven"); break;
    		case 12: printf("twelve"); break;
    		case 13: printf("thirteen"); break;
    		case 14: printf("fourteen"); break;
    		case 15: printf("fifteen"); break;
    		case 16: printf("sixteen"); break;
    		case 17: printf("seventeen"); break;
    		case 18: printf("eighteen"); break;
    		case 19: printf("nineteen"); break;
    		case 20: printf("twenty"); break;
    		default:
    			if(n<40)
    			printf("thirty");
    			else if(n<50)
    			printf("forty");
    			else if(n<60)
    			printf("fifty");
    
    			break;
    	}
    	
    	return ;
    }
    
    main()
    {
    	int h,m;
    	
    	scanf("%d%d",&h,&m);
    	
    	//输出小时 
    	if(h>20)
    	{
    		printTime(20);
    		printf(" ");
    		printTime(h%10);
    		printf(" ");
    	}
    	else
    	{
    		printTime(h);
    		printf(" ");
    	}
    	//输出分钟
    	if(m)
    	{
    			if(m>20)
    			{
    				printTime(m/10*10);
    				printf(" ");
    				printTime(m%10);
    			}
    			else
    			{
    				printTime(m);
    			}
    	}
    	else
    	{
    		printf("o'clock");
    	}
    	
    	printf("\n");
    	
    	return 0;
    } 
    

     

    /*
    基础练习 2n皇后问题
    
    问题描述
      给定一个n*n的棋盘,棋盘中有一些位置不能放皇后。现在要向棋盘中放入n个黑皇后
    
    和n个白皇后,使任意的两个黑皇后都不在同一行、同一列或同一条对角线上,任意的两
    
    个白皇后都不在同一行、同一列或同一条对角线上。问总共有多少种放法?n小于等于8。
    输入格式
      输入的第一行为一个整数n,表示棋盘的大小。
      接下来n行,每行n个0或1的整数,如果一个整数为1,表示对应的位置可以放皇后,
    
    如果一个整数为0,表示对应的位置不可以放皇后。
    输出格式
      输出一个整数,表示总共有多少种放法。
    样例输入
    4
    1 1 1 1
    1 1 1 1
    1 1 1 1
    1 1 1 1
    样例输出
    2
    样例输入
    4
    1 0 1 1
    1 1 1 1
    1 1 1 1
    1 1 1 1
    样例输出
    0
    */
    #include<stdio.h>
    
    int sum=0;
    
    int p(int n,int x,int y,int m[][8],int s)
    {
        int i,j;
        for(i=x-1;i>=0;i--)
        {
            if(m[i][y]==s)return 0;
        }
        for(i=x-1,j=y-1;i>=0&&j>=0;i--,j--)
        {
            if(m[i][j]==s)return 0;
        }
        for(i=x-1,j=y+1;i>=0&&j<n;i--,j++)
        {
            if(m[i][j]==s)return 0;
        }
        return 1;
    }
    
    int h(int n,int x,int m[][8],int s)
    {
        int i;
        if(x==n)
        {
            if(s==2)h(n,0,m,3);
            else sum++;
            return 0;
        }
        for(i=0;i<n;i++)
        {
            if(m[x][i]!=1)continue;
            if(p(n,x,i,m,s))m[x][i]=s;
            else continue;
            h(n,x+1,m,s);
            m[x][i]=1;
        }
        return 0;
    }
    
    int main()
    {
        int n,m[8][8],i,j;
        
        scanf("%d",&n);
        for(i=0;i<n;i++)
        {
            for(j=0;j<n;j++)
            {
                scanf("%d",&m[i][j]);
            }
        }
        h(n,0,m,2);
        printf("%d",sum);
    
        return 0;
    }

     

    /*
    基础练习 Huffuman树 
     
    问题描述
      Huffman树在编码中有着广泛的应用。在这里,我们只关心Huffman树的构造过程。
      给出一列数{pi}={p0, p1, …, pn-1},用这列数构造Huffman树的过程如下:
      1. 找到{pi}中最小的两个数,设为pa和pb,将pa和pb从{pi}中删除掉,然后将它们的
    
    和加入到{pi}中。这个过程的费用记为pa + pb。
      2. 重复步骤1,直到{pi}中只剩下一个数。
      在上面的操作过程中,把所有的费用相加,就得到了构造Huffman树的总费用。
      本题任务:对于给定的一个数列,现在请你求出用该数列构造Huffman树的总费用。
    
      例如,对于数列{pi}={5, 3, 8, 2, 9},Huffman树的构造过程如下:
      1. 找到{5, 3, 8, 2, 9}中最小的两个数,分别是2和3,从{pi}中删除它们并将和5加入,
    
    得到{5, 8, 9, 5},费用为5。
      2. 找到{5, 8, 9, 5}中最小的两个数,分别是5和5,从{pi}中删除它们并将和10加入,得
    
    到{8, 9, 10},费用为10。
      3. 找到{8, 9, 10}中最小的两个数,分别是8和9,从{pi}中删除它们并将和17加入,得
    
    到{10, 17},费用为17。
      4. 找到{10, 17}中最小的两个数,分别是10和17,从{pi}中删除它们并将和27加入,得
    
    到{27},费用为27。
      5. 现在,数列中只剩下一个数27,构造过程结束,总费用为5+10+17+27=59。
    输入格式
      输入的第一行包含一个正整数n(n<=100)。
      接下来是n个正整数,表示p0, p1, …, pn-1,每个数不超过1000。
    输出格式
      输出用这些数构造Huffman树的总费用。
    样例输入
    5 3 8 2 9
    样例输出
    */
    #include <stdio.h>
    
    typedef struct
    {
        int a[100];
        int len;
    }huf;
    
    int sum=0;
    
    int del(huf* in,int t)
    {
        int i,j;
        for(i=0;i<in->len && in->a[i]!=t;i++);
        for(;i<in->len-1;i++)
            in->a[i]=in->a[i+1];
        in->len--;
        return 1;
    }
    
    int add(huf* in,int t)
    {
        in->a[in->len]=t;
        in->len++;
    }
    
    int find_two_mins(huf* in)
    {
        int i,j,t;
        int mina,minb;
    
        for(i=0;i<in->len-1;i++)
            for(j=i+1;j<in->len;j++)
                if(in->a[i]>in->a[j])
                {
                    t=in->a[i];
                    in->a[i]=in->a[j];
                    in->a[j]=t;
                }
        mina=in->a[0];
        minb=in->a[1];
        del(in,mina);
        del(in,minb);
        add(in,mina+minb);
        return mina+minb;
    }
    
    int main()
    {
        huf in;
        int i,j,n;
        scanf("%d",&n);
        in.len=n;
        for(i=0;i<n;i++)
            scanf("%d",&in.a[i]);
    
        while(1)
        {
            if(in.len==2)
            {
                sum=sum+in.a[0]+in.a[1];
                break;
            }
            sum+=find_two_mins(&in);
        }
        printf("%d",sum);
    
        return 0;
    }

     

    /*
    基础练习 高精度加法
    
    问题描述
      输入两个整数a和b,输出这两个整数的和。a和b都不超过100位。
    算法描述
      由于a和b都比较大,所以不能直接使用语言中的标准数据类型来存储。对于这种问题
    
    ,一般使用数组来处理。
      定义一个数组A,A[0]用于存储a的个位,A[1]用于存储a的十位,依此类推。同样可以
    
    用一个数组B来存储b。
      计算c = a + b的时候,首先将A[0]与B[0]相加,如果有进位产生,则把进位(即和的
    
    十位数)存入r,把和的个位数存入C[0],即C[0]等于(A[0]+B[0])%10。然后计算A[1]与B[1]
    
    相加,这时还应将低位进上来的值r也加起来,即C[1]应该是A[1]、B[1]和r三个数的和.如
    
    果又有进位产生,则仍可将新的进位存入到r中,和的个位存到C[1]中。依此类推,即可求
    
    出C的所有位。
      最后将C输出即可。
    输入格式
      输入包括两行,第一行为一个非负整数a,第二行为一个非负整数b。两个整数都不超
    
    过100位,两数的最高位都不是0。
    输出格式
      输出一行,表示a + b的值。
    样例输入
    20100122201001221234567890
    2010012220100122
    样例输出
    20100122203011233454668012
    */
    #include <stdio.h>
    #include <string.h>
    #define MaxSize 100+5
    
    //逆序输出数组,不输出前导0 
    void printArray(int P[])
    {
        int i=MaxSize-1;
        
        while(!P[i])
        {
            i--;
        }
        
        while(i>=0)
        {
            printf("%d",P[i]);
            i--;
        }
        
        printf("\n");
        
        return ;
    }
    
    //高数相加 
    void getResult(char a[],char b[],int c[],int a_lenth,int b_lenth)
    {
        int next=0,i=0;
         
        while(a_lenth&&b_lenth)
        {
            c[i++]=((a[--a_lenth]-'0')+(b[--b_lenth]-'0')+next)%10;
            next=((a[a_lenth]-'0')+(b[b_lenth]-'0')+next)/10;
        }
        
        if(a_lenth==b_lenth)
        {
            c[i++]=next;
        }
        
        while(a_lenth)
        {
            c[i++]=(a[--a_lenth]-'0'+next)%10;
            next=(a[a_lenth]-'0'+next)/10;
        }
        
        return ;
    }
    
    main()
    {
        char A[MaxSize],B[MaxSize];
        int C[MaxSize];
        
        memset(C,0,sizeof(C));
        
        gets(A);
        gets(B);
        
        if(strlen(A)>=strlen(B))
        getResult(A,B,C,strlen(A),strlen(B));
        else
        getResult(B,A,C,strlen(B),strlen(A));
        
        printArray(C);
        
        return 0;
    }
    /*
    #include<stdio.h>
    #include<string.h>
    #include<stdlib.h>
    void f(char a[],char b[])
    {
        int w=200,i,j,la,lb;
        la=strlen(a);lb=strlen(b);
        char c[200];
        for(i=la;i<w;i++)a[i]=48;
        for(i=lb;i<w;i++)b[i]=48;
        a[w-1]=0;b[w-1]=0;
        for(i=0;i<la;i++)c[i]=a[i];
        for(i=0;i<w-1-la;i++)a[i]=48;j=0;
        for(i=w-1-la;i<w-1;i++){a[i]=c[j];j++;}
    
        for(i=0;i<lb;i++)c[i]=b[i];
        for(i=0;i<w-1-lb;i++)b[i]=48;j=0;
        for(i=w-1-lb;i<w-1;i++){b[i]=c[j];j++;}
    
        for(i=w;i>=0;i--)
        {
            j=a[i]+b[i]-96;
            if(j>9)a[i-1]=a[i-1]+j/10;
            c[i]=j%10+48;
        }
        c[w-1]=0;
        for(i=0;i<w;i++)if(c[i]!='0')break;
        for(;i<w-1;i++)printf("%c",c[i]);printf("\n");
    }
    
    int main()
    {
        char a[200],b[200];gets(a);gets(b);
        f(a,b);
    return 0;
    }
    
    */

     

    /*
    基础练习 阶乘计算
    
    问题描述
      输入一个正整数n,输出n!的值。
      其中n!=1*2*3*…*n。
    算法描述
      n!可能很大,而计算机能表示的整数范围有限,需要使用高精度计算的方法。使用一个数组A来表示一个大整数a,A[0]表示a的个位,A[1]表示a的十位,依次类推。
      将a乘以一个整数k变为将数组A的每一个元素都乘以k,请注意处理相应的进位。
      首先将a设为1,然后乘2,乘3,当乘到n时,即得到了n!的值。
    输入格式
      输入包含一个正整数n,n<=1000。
    输出格式
      输出n!的准确值。
    样例输入
    10
    样例输出
    3628800
    */
    #include <stdio.h>
    #include <string.h>
    #define MaxSize 3000+5
    
    void resultProduct(int P[],int num)
    {
        int i,tp=0,st=0;
        
        for(i=0;i<MaxSize;i++)
        {
            st=tp;
            tp=(P[i]*num+st)/10;
            P[i]=(P[i]*num+st)%10;
        }
    
        return ;
    }
    
    void printArray(int P[])
    {
        int i=MaxSize-1;
        
        while(!P[i])
        {
            i--;
        }
        
        while(i>=0)
        {
            printf("%d",P[i]);
            i--;
        }
        
        printf("\n");
        
        return ;
    }
    
    main()
    {
        int A[MaxSize],n;
        int i;
        
        //数组清零且个位初始化为1 
        memset(A,0,MaxSize*sizeof(int)); 
        A[0]=1;
    
        scanf("%d",&n);
        //用i依次乘以数组A 
        for(i=2;i<=n;i++)
        {
            resultProduct(A,i);
        }
        
        printArray(A);
        printf("\n");    
    
        return 0;
    }
    /*
    #include <stdio.h>
    #define N 10000
    int main()
    {
        int a[N]={1};
        int k=0,l=1,n;
        int i,j;
        scanf("%d",&n);
        for(i=1;i<=n;i++)
        {
            for(j=0;j<l;j++)
            {
                a[j]=a[j]*i+k;
                k=a[j]/10000;
                a[j]=a[j]%10000;
            }
            if(k)
            {
                a[j]=k;
                l++;
                k=0;
            }
        }
        printf("%d",a[l-1]);
        for(i=l-2;i>=0;i--)
            printf("%04d",a[i]);
        printf("\n");
        return 0;
    }
    */

     

     

     

    GoToNextPart

     

    展开全文
  • 算法-蓝桥杯习题(3-3)

    万次阅读 2016-02-01 21:42:32
    蓝桥杯习题 目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1))Go...
  • 算法-蓝桥杯习题(3-2)

    万次阅读 2016-03-05 00:45:57
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...
  • 算法-蓝桥杯习题(5-1)

    万次阅读 2016-01-16 21:14:49
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...
  • 算法-蓝桥杯习题(4-1)

    万次阅读 2016-01-17 16:07:09
    蓝桥杯习题 目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1))Go...
  • 算法-蓝桥杯习题(4-3)

    千次阅读 2016-11-24 23:42:43
    蓝桥杯习题 目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1))Go...
  • 算法-蓝桥杯习题(5-2)

    千次阅读 2016-01-16 21:25:23
    蓝桥杯习题 目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1))Go...
  • 算法-蓝桥杯习题(3-4)

    千次阅读 2016-01-22 23:21:44
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...
  • 算法-蓝桥杯习题(3-5)

    千次阅读 2016-01-22 20:37:02
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...
  • 算法-蓝桥杯习题(3-6)

    千次阅读 2016-01-22 20:51:28
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...
  • 算法-蓝桥杯习题(六)

    千次阅读 2016-01-09 14:45:00
    蓝桥杯习题 蓝桥杯练习系统习题加答案更新新地址(已更新200左右习题) http://blog.csdn.net/rodestillfaraway 目录 算法训练(详见 算法-蓝桥杯习题(一))Go 算法训练(详见 算法-蓝桥杯习题(二))...
  • 算法-蓝桥杯习题(4-2)

    千次阅读 2016-06-11 22:50:55
    蓝桥杯习题   目录   入门训练(详见 算法-蓝桥杯习题(1-1))Go   基础练习(详见 算法-蓝桥杯习题(2-1))Go 基础练习(详见 算法-蓝桥杯习题(2-2))Go 算法训练(详见 算法-蓝桥杯习题(3-1)...
  • 蓝桥杯习题 蓝桥杯练习系统习题加答案更新新地址(已更新200左右习题) http://blog.csdn.net/rodestillfaraway 目录 算法训练(详见 算法-蓝桥杯习题(一))Go 算法训练(详见 算法-蓝桥杯习题(二))...
  • 蓝桥杯习题 蓝桥杯练习系统习题加答案更新新地址(已更新200左右习题) http://blog.csdn.net/rodestillfaraway 目录 算法训练(详见 算法-蓝桥杯习题(一))Go 算法训练(详见 算法-蓝桥杯习题(二))...
  • 蓝桥杯习题 蓝桥杯练习系统习题加答案更新新地址(已更新200左右习题) http://blog.csdn.net/rodestillfaraway 目录 入门训练(详见 算法-蓝桥杯习题(一))Go 算法训练(详见 算法-蓝桥杯习题(一))...
  • 蓝桥杯习题 蓝桥杯练习系统习题加答案更新新地址(已更新200左右习题) http://blog.csdn.net/rodestillfaraway 目录 算法训练(详见 算法-蓝桥杯习题(一))Go 算法训练(详见 算法-蓝桥杯习题(二))...
  • 蓝桥杯习题真题汇总(含参考代码,含VIP题目),有JAVA、C++C语言三种答案。
  • 蓝桥杯习题题解

    2019-01-14 15:51:37
    博主要开始准备蓝桥杯了 所以更新一下自己蓝桥杯的刷题历程~ 历届真题: 历届试题 分考场

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 1,496
精华内容 598
关键字:

蓝桥杯习题