PTA-练习4

目录

实验7-1-1 简化的插入排序

实验7-1-5 交换最小值和最大值

实验7-1-6 求一批整数中出现最多的个位数字

实验7-1-8 找出不是两个数组共有的元素

实验7-1-9 求整数序列中出现次数最多的数

实验7-1-10 组个最小数

实验7-1-11 装箱问题 


实验7-1-1 简化的插入排序

//先将数据存入一个数组,然后遍历数组找到第一个大于x的数字,然后将其数据后移
//然后空出来的位置则保存x
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>

int main(){

    int n;
    scanf("%d",&n);
    int a[n+1];
    for(int i=0;i<n;i++){
        scanf("%d ",&a[i]);
    }
    int x;
    scanf("%d",&x);
    //n==0的时候
    if(n==0){
        printf("%d ",x);
        return 0;
    }
        
    int i=0;
    while(a[i]<x&&i<n){//查找x应该插入的位置
        i++;
    }

    //当所有元素都小于x的时候,直接插入最后
    if(i==n){
        a[i]=x;
        for(int i=0;i<=n;i++){
            printf("%d ",a[i]);
        }
        return 0;
    }
    //将i~n元素向后移一位
    for(int j=n-1;j>=i;j--){
        a[j+1]=a[j];
    }
    a[i]=x;

    //输出看看
    for(int i=0;i<=n;i++){
        printf("%d ",a[i]);
    }
    return 0;
}

实验7-1-5 交换最小值和最大值

注意:这里是交换完第一部之后的数组,再执行第二部交换。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
int main(){
    int n;
    scanf("%d",&n);
    int a[n];
    for(int i=0;i<n;i++){
        scanf("%d",&a[i]);
    }

    int min=a[0],minval=0;
    for(int i=1;i<n;i++){
        if(a[i]<min){
            minval=i;
            min=a[i];
        }
    }// of for
    int temp=a[minval];
    a[minval]=a[0];
    a[0]=temp;

    int max=a[0],maxval=0;
    for(int i=1;i<n;i++){
        if(a[i]>max){
            max=a[i];
            maxval=i;
        }
    }
    temp=a[maxval];
    a[maxval]=a[n-1];
    a[n-1]=temp;

    for(int i=0;i<n;i++){
        printf("%d ",a[i]);
    }
}

实验7-1-6 求一批整数中出现最多的个位数字

//思路:把每个数字分解成个位,直接%10,
//然后出现一个数字就在相应的数组a[10]上面+10

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
int main(){
    int n;
    scanf("%d",&n);
    int a[n];
    for(int i=0;i<n;i++){
        scanf("%d",&a[i]);
    }

    int b[10]={0};//用于记录0-9出现的次数
    for(int i=0;i<n;i++){
        if(a[i]==0){
            b[0]++;
        }
        while(a[i]>0){
            int x=a[i]%10;
            b[x]++;
            a[i]=a[i]/10;
        }
    }

    int max=b[0],maxval=0;
    for(int i=1;i<10;i++){
        if(b[i]>max){
            max=b[i];
            maxval=i;
        }
    }
    printf("%d:",max);

    for(int i=0;i<10;i++){
        if(b[i]==max){
            printf(" %d",i);
        }
    }
    
    return 0;
}


实验7-1-8 找出不是两个数组共有的元素

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
//构造一个函数如果数字x出现在数组c中,则返回1
int cunzai(int *a,int n,int x){
    for(int i=0;i<n;i++){
        if(a[i]==x){
            return 1;
        }
    }
    return 0;
}

int main(){
    int N1;
    scanf("%d",&N1);
    int a[N1];
    for(int i=0;i<N1;i++){
        scanf("%d",&a[i]);
    }
    int N2;
    scanf("%d",&N2);
    int b[N2];
    for(int i=0;i<N2;i++){
        scanf("%d",&b[i]);
    }

    int c[20];
    int cc=0;//非公共元素保存在c中
    for(int i=0;i<N1;i++){
        if(cunzai(b,N2,a[i])==0&&cunzai(c,N2,a[i])==0){
            c[cc]=a[i];
            cc++;
        }
    }//判断第一个数组中的元素,非公有,保存在c中
    for(int i=0;i<N2;i++){
        if(!cunzai(a,N1,b[i])&&!cunzai(c,N1,b[i])){
            c[cc]=b[i];
            cc++;
        }
    }//判断第二个数组中的元素,非公有,保存在c中
    
    for(int i=0;i<cc;i++){
        if(i==cc-1){
            printf("%d",c[i]);
        }else{
             printf("%d ",c[i]);
        }
       
    }
    return 0;
}

实验7-1-9 求整数序列中出现次数最多的数


#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>

int main(){
    int N;
    scanf("%d",&N);
    int a[1000];
    for(int i=0;i<N;i++){
        scanf("%d",&a[i]);
    }

    int max=0,num=0,x;
    for(int i=0;i<N;i++){
        num=1;
        for(int j=i+1;j<N;j++){//后面有几个相同的??
            if(a[i]==a[j]){
                num++;
            }
        }
        if(num>max){
            max=num;
            x=a[i];
        }
    }
    printf("%d %d",x,max);
}

实验7-1-10 组个最小数

其实不用找到这个最小的值,直接按位输出就可以了。

//第一位必须从a[1]-a[9]中取最小的,数字之和就表示位数

//然后从第二位开始就a[0]-a[9]中取最小的,每去一个数就a[i]--


#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>

int main(){
   
    int a[10];
    int sum=0;
    for(int i=0;i<10;i++){
        scanf("%d",&a[i]);
        sum=sum+a[i];
    }//a[i]表示i所有的个数
    
    for(int i=1;i<10;i++){
        if(a[i]!=0){
            printf("%d",i);
            a[i]--;
            sum--;
            break;
        }
    }//找到了第一位

    for(int i=0;i<10;){
        if(a[i]!=0){
            printf("%d",i);
            sum--;
            a[i]--;
        }
        if(a[i]==0){
            i++;
        }
    }
    
}


实验7-1-11 装箱问题 

//给你N个箱子,每个箱子初始装入都是0
//,每个货物装箱都是从第一个箱子开始看,直到找到100-已装货物>=要装货,
//每装入一个货物就+重量,

//a[i]表示第i个箱子,现在装有的货物


#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>

int main(){

    int N=0;
    scanf("%d",&N);
    int a[N+1];
    for(int i=0;i<N+1;i++){
        a[i]=0;
    }
    for(int i=0;i<N;i++){
        int s;
        scanf("%d",&s);
        for(int j=1;j<N+1;j++){
            if(100-a[j]>=s){
                printf("%d %d\n",s,j);
                a[j]=a[j]+s;
                break;
            }
        }
    }
    int num=0;
    for(int i=1;i<N+1;i++){
        if(a[i]!=0){
            num++;
        }
    }
    printf("%d",num);
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/474879.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

明明是字符串,为什么写的是char *str

字符串匹配 /* 暴力 将目标串s的第一个字符和模式串T的第一个字符进行匹配 相等&#xff0c;则比较s的第二个和T的第三个 不想等&#xff0c;比较s的第二个和T的第一个 如此循环 O(m*n)*/ #include<bits/stdc.h> using namespace std;int BF(char *str,char *sub) { //s…

聊聊SAP内存和ABAP内存

1、区别与联系 SAP内存&#xff08;SAP Memory&#xff09;和ABAP内存&#xff08;ABAP Memory&#xff09;&#xff0c;两者都可用于编程中的数据传递&#xff0c;将数据通过ID进行绑定&#xff0c;之后在其他程序中通过ID获取。 1.1、语法区别 1、SAP内存通过SET/GET PARA…

node.js实战 笔记 (补补前端Orz

Node.js是什么 Node.js是一个基于Chrome V8引擎的javascript运行环境。 Node.js使用一个事件驱动的非阻塞式IO模型。 Node.js和浏览器的区别 Node.js可以操作电脑&#xff0c;浏览器的javascript环境只能操作浏览器 Node.js多了一些内置模块&#xff0c;以及环境变量&#x…

【Redis】聊聊Redis常见数据类型底层结构

对于Redis来说&#xff0c;其实我们操作的数据类型就是String,List、Set、Zset、Hash&#xff0c;但是具体低层使用什么编码进行存储&#xff0c;在面试中是一个高频面试题&#xff0c;所以今天大概整理下对应的。 RedisObject与DictEntry 其实对于key来说一般都是String类型…

基于springboot+vue的在线互动学习网站

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

下载并安装ChatGPT Chrome扩展插件

解压 打开chrome浏览器并下面的步骤操作 参考链接&#xff1a; http://doc.xutongbao.top/docs/ai/994

华为配置Wi-Fi终端定位实验

配置Wi-Fi终端定位示例 组网图形 图1 配置Wi-Fi终端定位示例组网图 业务需求组网需求数据规划配置思路配置注意事项操作步骤配置文件 业务需求 管理员希望在已有WLAN覆盖业务的基础上&#xff0c;还可以定位覆盖区域内的终端位置信息。使用Wi-Fi终端定位方案&#xff0c;无需新…

C语言基础(十六)通过指针来输入和获取结构体的变量值

老样子&#xff0c;先看代码 #include <stdio.h> #include <string.h>#define NLEN 30 struct namect{char fname[NLEN];char lname[NLEN];int letters; };void getinfo(struct namect *); void makeinfo(struct namect *ptr); void showinfo(const struct namec…

如何在 Postman 中执行断言测试?

在当今的软件构建流程中&#xff0c;应用程序编程接口&#xff0c;简称 API&#xff0c;起到了不可或缺的作用&#xff0c;它们使得不同的软件应用能够互相沟通和交换数据。随着应用程序的不断演进变得越发复杂&#xff0c;保障API的可靠性及其稳定性显得格外关键。正因如此&am…

使用appuploder流程

使用appuploder流程笔记 1.如何没有账号去apple官网注册一个&#xff0c;地址&#xff1a;https://developer.apple.com/account 2.下载解压appuploder&#xff0c;双击打开&#xff0c;用刚刚注册的账号登录&#xff0c;下载地址&#xff1a;http://www.applicationloader.n…

员工上班摸鱼怎么管理

在当今快节奏的工作环境中&#xff0c;员工上班摸鱼的现象屡见不鲜。 这种行为不仅影响了工作效率&#xff0c;还可能对团队氛围和企业文化造成负面影响。 员工上班摸鱼的原因&#xff1f; 有些员工可能是因为工作压力过大&#xff0c;需要短暂的休息和放松&#xff1b; 有些…

人脸表情识别系统项目完整实现详解——(二)使用SSD模型检测人脸

摘要&#xff1a;人脸检测是人脸表情识别系统中至关重要的一环&#xff0c;其准确性直接影响到整个系统的性能表现。本文介绍了使用SSD模型和OpenCV进行高效人脸检测的完整代码实现。我们详细介绍了SSD人脸检测器的工作原理&#xff0c;包括如何加载预训练的SSD模型&#xff0c…

C语言经典算法-5

文章目录 其他经典例题跳转链接26.约瑟夫问题&#xff08;Josephus Problem&#xff09;27.排列组合28.格雷码&#xff08;Gray Code&#xff09;29.产生可能的集合30.m元素集合的n个元素子集 其他经典例题跳转链接 C语言经典算法-1 1.汉若塔 2. 费式数列 3. 巴斯卡三角形 4. …

【Spring IOC/DI】bean 的 5 种注册 与 5 种注入

什么是 bean 一个 bean 就是一个实例化对象 User user new User() 上面这行代码中的 user&#xff0c; 就是 User 类的实例化对象&#xff0c;即一个 bean&#xff08;User Bean&#xff09; 什么是 IOC Inversion of Control 控制反转&#xff08;反转对 bean 的控制&#…

ElasticSearch之Ingest Pipeline和Painless Script

写在前面 如果是我们需要在写入文档或者是返回文档时&#xff0c;进行修改字段值&#xff0c;或者增加字段等操作时&#xff0c;就可以考虑使用ingest pipeline和painless script。如下的需求&#xff1a; 1:ingest pipeline 在es 5中引入了一种新的节点类型ingest node&am…

安科瑞智能断路器产品介绍【可监可控 远程操控 短路保护】

开发背景 过去几年智慧用电的产品应用中&#xff0c;大多数只安装于进线测。主要存在以下几个问题&#xff1a;难定位&#xff0c;不知道具体哪个回路出线问题&#xff0c;排查困难&#xff1b;出线过载或线缆温度过高无法知晓&#xff1b;即使是出线回路安装了的场景&#xf…

个人开发App成功上架手机应用市场的关键步骤

目录 1. 苹果审核和APP备案 2. APP上架操作步骤 3. 审核和发布 4. 上线工作 总结 参考资料 在当前移动应用市场竞争激烈的背景下&#xff0c;个人开发App如何成功上架成为开发者们必须面对的重要任务。本文将重点介绍自建App上架至手机应用市场的流程&#xff0c;包括苹果…

2024你必须知道的外贸形势!

2024年外贸形势下的新机会在哪里&#xff1f;今天Erica给大家总结了几个主要市场的形式。 喜欢的话点点关注吧~ 欧美市场2024年应谨慎开发 海关总署11月7日发布的数据显示&#xff0c;前10个月&#xff0c;今年中国对欧洲出口呈下降趋势&#xff0c;中国与欧盟贸易总值为4.5…

前端项目,个人笔记(六)【无限滚动 + 拦截器】

目录 1、无限滚动 2、使用pinia进行用户数据持久化 3、完善个人笔记三中的拦截器 请求拦截器&#xff1a; 响应拦截器&#xff1a; 1、无限滚动 使用elementplus中提供的&#xff1a; 代码&#xff1a; <div class"body" v-infinite-scroll"load"…

【复现】某指挥调度管理平台 SQL注入漏洞_66

目录 一.概述 二 .漏洞影响 三.漏洞复现 1. 漏洞一&#xff1a; 四.修复建议&#xff1a; 五. 搜索语法&#xff1a; 六.免责声明 一.概述 该平台提供强大的指挥调度功能&#xff0c;可以实时监控和管理通信网络设备、维护人员和工作任务等。用户可以通过该平台发送指令…