心得:数组元素交换

简介: 心得:数组元素交换

今天干了一件蠢事,对着一个水题钻牛角尖,pta一个测试点过不了纠结好久,难题都没有怎么花时间去看,自己改bug改着改着越来越离谱,改着改着搞出一个long long对应d%的小错误把我整懵了,我还以为是别的问题,所以浪费不少时间。

原题:

L2 数组元素交换 (5 分)

数组元素交换,要求:(1)最大的元素与第一个元素交换(2)最小的元素与最后一个元素交换。

输入格式:
输入一行字符串(由不同的整数组成,以空格分开)

输出格式:
首先以数组形式输出初始字符串(一行一个数字),然后以数组形式输出完成交换后的字符串(一行一个数字)。
089f66dcd81149a7b6e0d8e41bfa0c35.png
注意这个题目的两个步骤的进行,当第一个元素是最小元素的话,这个交换是有问题的,这个代码是将第一个元素和最大元素交换,如果第一个元素就是最小元素,那么最大元素交换后,最小元素不再是第一个元素,而是原先的最大元素位置。所以交换最小元素时,还是和第一个元素交换就错了。要对这个情况进行特殊判断,如果第一个元素就是最大元素,那么需要将n值改为m才行。

例:1 2 3 4 5输入,先进行第一个步骤的操作“最大值和第一个数交换”后为52341,再进行第二个步骤“最小值和最后一个数交换”后为52341。

    但是从题目通过结果来看,如果没有考虑到上面这些,就会像这样:代码1 2 3 4 5输入,得出的结果是12345->52341->12345,结果为12345,对于这个题目可以AC,应该是没有设置这个测试点,但是这种直接不考虑情况的直接交换是存在错误的,下面给出考虑到这点的代码:
#include<stdio.h>
#include<string.h>
int a[10005],i=0,j,m=0,n=0,b;//在改bug的时候想着把数据开大一点所以int改成了long long,
int main ()                     //但是后面的%d忘记改成%lld了,导致在pta中测试点不过.
{    
    while(~scanf("%d",&b))
    {
         a[i++] = b;
        if ('\n' == getchar())
             break;
    }
    for(j=0;j<i;j++)
        {
            printf("%d\n",a[j]);
        }
        
    int max=a[0];
    for(j=0;j<i;j++)
    {
        if(a[j]>max)
        {
            max=a[j];
            m=j;
        }
    }
        int t=a[0];
        a[0]=a[m];
        a[m]=t; 
     // 最大的元素与第一个元素交换       
    int min=a[0];
    for(j=0;j<i;j++)
    {
        
        if(a[j]<min)
        {
            min=a[j];
            n=j;
        }
    }    
        t=a[i-1];
        a[i-1]=a[n];
        a[n]=t;
    // 最小的元素与最后一个元素交换
        for(j=0;j<i;j++)
        {
            printf("%d\n",a[j]);
        }
 
    return 0;
    
} 
 

关于定义一个long long类型,用%d打印的结果:

printf("%d %d\n",a,b);
a,b入栈时是64位数,而printf是以32位数解析"%d"格式的,即printf("%d %d\n",a,b);只解析了a的低32位和高32位。
printf("%d %d,%d %d\n",a,b);
这样会输出:1 0,2 0

我也在网上查找了一些资料,下面供大家参考:

这是一个csdn的博友的文章:https://blog.csdn.net/qq_39014877/article/details/104987700

主要是%d和long long不匹配,看看文章:https://blog.csdn.net/arong1234/article/details/2456455

相关文章
|
BI
7-6 sdut-C语言实验-最长上升子序列
7-6 sdut-C语言实验-最长上升子序列
247 1
|
6月前
|
人工智能 自然语言处理 搜索推荐
企业客户服务效率低、体验差,如何通过大模型技术改善?一文了解面向客户服务全场景的行业大模型的3大应用方向
本文三桥君探讨了大模型技术在客户服务领域的应用与实践。从架构设计出发,详细解析了面向客户、客服和运营三大场景的智能功能模块,包括业务咨询、情感关怀、智能点选、知识采编等12项核心功能。AI产品专家三桥君指出,通过行业大模型定制、多源数据整合等技术手段,企业可实现客户服务的智能化升级,显著提升客户体验和运营效率。
379 0
|
4月前
|
安全 Java 测试技术
Burp Suite使用及BruteForc_test靶场实战
Burp Suite 是一款用于Web应用安全测试的集成平台,包含多个协同工具,支持请求拦截、漏洞扫描、暴力破解等功能,适用于渗透测试,提升安全测试效率。
497 0
Burp Suite使用及BruteForc_test靶场实战
7-5 sdut-C语言实验-最长公共子序列
7-5 sdut-C语言实验-最长公共子序列
284 0
|
11月前
|
Python
python3多线程中使用线程睡眠
本文详细介绍了Python3多线程编程中使用线程睡眠的基本方法和应用场景。通过 `time.sleep()`函数,可以使线程暂停执行一段指定的时间,从而控制线程的执行节奏。通过实际示例演示了如何在多线程中使用线程睡眠来实现计数器和下载器功能。希望本文能帮助您更好地理解和应用Python多线程编程,提高程序的并发能力和执行效率。
416 20
|
数据采集 安全 API
高级技术文章:使用 Kotlin 和 Unirest 构建高效的 Facebook 图像爬虫
高级技术文章:使用 Kotlin 和 Unirest 构建高效的 Facebook 图像爬虫
|
11月前
|
存储 人工智能 算法
C 408—《数据结构》算法题基础篇—数组(通俗易懂)
408考研——《数据结构》算法题基础篇之数组。(408算法题的入门)
704 23
|
存储 API
Activiti七大接口,28张表详解
Activiti七大接口,28张表详解
798 0
|
存储 负载均衡 算法
|
Web App开发 JavaScript 前端开发
不光好上手,功能还特强的 Vue 3组件!且开源免费!
不光好上手,功能还特强的 Vue 3组件!且开源免费!