OJ 2018/3/12

/*
A1025. 字符串对比
*/
#include<stdio.h>
#include<string.h>
int main()
{
    char a[11],b[11];
    gets(a);
    gets(b);    
    int alen=strlen(a);
    int blen=strlen(b); 
    if(alen<1||alen>10||blen<1||blen>10)
        return 0;
    if(alen!=blen)
    {
        printf("1\n");
        return 0;
    }
    else
    {
        int temp=alen;
        int temp2=0;//相同的个数
        int temp3=0;
        while(temp)
        {
            int aint=a[temp-1];
            int bint=b[temp-1];
            if(aint == bint)
            {
                temp2++;
                temp3++;
            }
            else
            {


                if(aint>bint)
                    aint -= 32;
                else
                    bint -= 32;
                    if(aint==bint)
                    temp3++;
                    }
            temp--;
        }


        if(temp2 == alen)
        {
            printf("2\n");
            return 0;
        }
        if(temp3 == alen)
        {
            printf("3\n");
            return 0;
        }
        else 
        {
            printf("4\n");
            return 0;
        }
    }
    return 0;
}
/*
A1026. 字符统计
*/
#include<stdio.h>
#include<string.h>
int main()
{
    char a[101];
    gets(a);
    int b[101]={0};
    int max=0;
    int alen=strlen(a);
    int i=0;
    for(i=0;i<alen;i++)
    {
        b[a[i]-96] +=1;
        if((a[i]-95)>max)
            max=a[i]-95;
    }
    for(i=0;i<max;i++)
    {
        if(b[i]!=0)
        printf("%c %d\n",i+96,b[i]);
    }
    return 0;
}
/*
A1028. 选择计算
*/
#include<stdio.h>
int gy(int a,int b)
{
/*  
最小公倍数=两数乘积除以最大公因数
最大公约数: 辗转相除法    
*/
    int temp;
    int yu=1;
    int shang;
    while(yu)
    {
        shang=a/b;
        yu=a%b; 
        temp=b;
        b=a%b;
        a=temp;
    }
    return temp;
}

int main()
{
    int x,y,z;
    scanf("%d %d %d",&x,&y,&z);
    switch(z)
    {
    case 1:printf("%d",x+y);break;
    case 2:printf("%d",x-y);break;
    case 3:printf("%d",x*y);break;
    case 4:printf("%d",x/y);break;
    case 5:printf("%d",x%y);break;
    case 6:printf("%d",gy(x,y));break;
    case 7:printf("%d",x*y/gy(x,y));break;  
    }   
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值