2017程序设计练习题之暴力专题

A题 Average

//这题就是求和减去最大值和最小值然后除以n-2
#include<bits/stdc++.h>

using namespace std;

int main(){
    int n;
    while(scanf("%d",&n)&&n){
        int Max = -1;
        int Min = 110;
        int sum = 0;
        for(int i = 0;i < n;i++){
            int t;
            scanf("%d",&t);
            sum += t;
            Max = max(Max,t);
            Min = min(Min,t);
        }
        sum -= Max;
        sum -= Min;
        n -= 2;
        printf("%.1f\n",(double)sum/n);
    }
    return 0;
}

B题 A+BIV

//暴力模拟a和b分别不断去乘以十,看谁的次数少,注意b的话输出是负值
#include<bits/stdc++.h>

using namespace std;

int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        int a,b,c;
        scanf("%d+%d=%d",&a,&b,&c);
        int o = a;
        int p = b;
        int q = c;
        int i = -1;
        while(i++<10&&o+p!=q){
            o*=10;
        }
        o = a;
        p = b;
        q = c;
        int j = -1;
        while(j++<10&&o+p!=q){
            p*=10;
        }
        if(i<=j)printf("%d\n",i);
        else printf("%d\n",-j);
    }
    return 0;
}

C题

//用到韦达定理(a+b)平方-4a*b=(a-b)平方,然后判断a-b是不是整数,在判断这样解得的a和b是不是整数就可以了
#include<bits/stdc++.h>

using namespace std;

int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        __int64 a,b;
        scanf("%I64d%I64d",&a,&b);
        __int64 t = a * a - 4 * b;
        if(t < 0){
            puts("None");
            continue;
        }
        __int64 p = (int)sqrt(t);
        if(p * p != t){
            puts("None");
        }else {
            if((p+a)%2==1){
                puts("None");
            }else{
                printf("%I64d %I64d\n",min((a-p)/2,(a+p)/2),max((a-p)/2,(a+p)/2));
            }
        }
    }
    return 0;
}

D题 Root

//这题不难,就是解方程,但是真的贼恶心,我想你肯定经历过好多发wa才看见A的彩虹....
#include<bits/stdc++.h>

using namespace std;

int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        int a,b,c;
        scanf("%d%d%d",&a,&b,&c);
        if(c==1){
            if(a==b){
                if(a==0)puts("1");
                else puts("0");
            }
            else puts("None");
        }else
        {
            if((a-c*b)==0&&b!=0)    printf("0\n");
            else if((a-c*b)/(c-1)<0) printf("None\n");
            else if((a-c*b)%(c-1)==0)
            {
                 if((a-c*b)/(c-1)==(-b)) printf("None\n");
                else    printf("%d\n",(a-c*b)/(c-1));
            }
            else        printf("None\n");
        }
    }
    return 0;
}

E题 A+BVIII

//这题的话首先要理解因子分解,任何一个合数都是由素数乘来的。比如12 = 2^2*3而直到最小因子分解式之后就是每个素数上面的次数+1的乘积,12的话就是(2+1)*(1+1)=6不过要注意下这个数就是素数的处理。剩下的就是素数打表等知识了。
#include<bits/stdc++.h>

using namespace std;

const int maxn = 100010;

int prime[maxn];
bool primeflag[maxn];
int cnt = 0;
void Prime(){
    memset(primeflag,false,sizeof(primeflag));
    primeflag[1] = true;
    for(int i = 2; i < 1000;i++){
        if(!primeflag[i]){
            for(int j = i*i;j < maxn;j+=i)primeflag[j] = true;
        }
    }

    for(int i = 2;i < maxn;i++)if(primeflag[i] == false)prime[cnt++] = i;
    //for(int i = 0;i <100;i++)printf("%d\n",prime[i]);
}
int main(){
    Prime();
    int T;
    scanf("%d",&T);
    while(T--){
            int a,b;
        scanf("%d%d",&a,&b);
        int n = a + b;
        int tmp = sqrt(n) + 1;
        int res = 1;
        for(int i = 0; i < cnt&&prime[i] < tmp;i++){
            int num = 0;
            while(n % prime[i]==0){
                n /= prime[i];
                num++;
            }
            res *= (num+1);
        }
        if(n > 1)res *= 2;
        printf("%d\n",res);

    }
}

F题 Score

//暴力...不过要考虑impossible的情况
#include <stdio.h>
#include <string.h>

int main()
{
    int x,y;
    int m,n;
    char a[10] = {"Alice"},b[10] = {"Bob"},c[10],d[10] = {"Draw"};

    while (scanf("%d %d",&x,&y)!=EOF)
    {
        getchar();
        scanf("%s",c);
        if ((x<y)||(((x+y)%2!=0))||((strcmp(c,d)==0)&&(x%2)!=0)||(y!=0&&strcmp(c,d)==0)||(y==0&&strcmp(c,d)!=0))
        {
            printf("Impossible\n");
            continue;
        }

        if (strcmp(c,d)==0) printf("%d:%d\n",x/2,x/2);
        else if (strcmp(c,a)==0) printf("%d:%d\n",(x+y)/2,(x-y)/2);
        else printf("%d:%d\n",(x-y)/2,(x+y)/2);

    }
    return 0;
}

G题 Recetangle

//看我剧暴力的写法...
#include<bits/stdc++.h>

using namespace std;

int a[4],b[4];



int main(){
    int T;
    scanf("%d",&T);
    int n1,m1,n2,m2,x1,y1,x2,y2;
    while(T--){
        scanf("%d%d%d%d",&n1,&m1,&n2,&m2);
        scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
        a[0] = min(n1,n2);
        a[1] = min(m1,m2);
        a[2] = max(n1,n2);
        a[3] = max(m1,m2);
        b[0] = min(x1,x2);
        b[1] = min(y1,y2);
        b[2] = max(x1,x2);
        b[3] = max(y1,y2);
        int x = max(a[0],b[0]);
        int y = max(a[1],b[1]);
        int xx = min(a[2],b[2]);
        int yy = min(a[3],b[3]);
        if (x>=xx||y>=yy) printf("No\n");
        else printf("Yes\n");
    }
    return 0;
}
//1.判断是不是那32个 2.首字母是不是数字 3.有没有出现不是数字下划线字符的解
#include<bits/stdc++.h>

using namespace std;
char str[35][10]={"auto","break","case","char","const","continue","default","do",
    "double","else","enum","extern",
    "float","for","goto","if","int","long","register","return",
    "short","signed","sizeof","static",
    "struct","switch","typedef","union","unsigned","void","volatile",
    "while"};
bool ischar(char c){
    if((c>='A'&&c<='Z')||(c<='z'&&c>='a'))return true;
    else if(c=='_')return true;
    return false;
}
char s[50];
bool isdig(char c){
    if(c>='0'&&c<='9')return true;
    return false;
}
int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        scanf("%s",s);
        bool flag = true;
        //printf("%s\n",s);
        for(int i = 0;i < 32;i++){
            if(strcmp(s,str[i])==0){
                flag = false;
                break;
            }
        }
        int len = strlen(s);
        for(int i = 0;i < len;i++){
            if(i==0&&isdig(s[i]))flag = false;
            else if(!isdig(s[i])&&!ischar(s[i]))flag = false;
        }
        flag?puts("Yes"):puts("No");
    }
    return 0;
}

I题 Matrix Transposition

//结构体排序完之后 把里面的x和y输出顺序换下即可
#include<bits/stdc++.h>

using namespace std;
struct Node{
    int x,y,z;
}a[10000];

int cmp(Node c,Node d){
    if(c.y==d.y)return c.x<d.x;
    return c.y<d.y;
}
int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        int x,y,n;
        scanf("%d%d%d",&y,&x,&n);
        for(int i= 0;i < n;i++)scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].z);
        sort(a,a+n,cmp);
        //printf("========\n");
        for(int i= 0;i < n;i++)printf("%d %d %d\n",a[i].y,a[i].x,a[i].z);
        printf("\n");
    }
    return 0;
}

转载于:https://www.cnblogs.com/wlxtuacm/p/6940985.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
基于hal库的OLED显示屏驱动C语言实现源码.zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值