返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言--数字交换题目详解
  • 448
分享到

C语言--数字交换题目详解

2024-04-02 19:04:59 448人浏览 独家记忆
摘要

目录一、题目分析二、算法分析和设计心路历程位置分析分析交换算法回顾总结(问题核心)三、编写代码四、出现问题总结一、题目分析 大致题意就是通过交换把最小的数放到最前面,最大的数放最后

一、题目分析

整型提升例题解析

大致题意就是通过交换把最小的数放到最前面,最大的数放最后面。另外要求编写三个函数。

二、算法分析和设计

心路历程

题目有四个关键词,最大值和最小值,第一个数和最后一个数。这就是我们分析的重点。
接下来先对最大值和最小值分析,如果两个数的值相同,位置相同,说明所有的数据都相同,我们什么都不用做。如果两个数的值不同,位置肯定也不同,所以最大值和最小值的位置关系是分析的重点。

位置分析

1.问:在头、身、尾三种位置中,最大值和最小值的位置有多少种?

解法一: 最大值有3种可能,最小值有3种可能,但头尾只能容纳一个值,有2种不合法,所以共有3*3-2=7种情况。

解法二:最大值在头,最小值有2种可能;最大值在身,最小值有3种可能;最大值在尾,最小值有2种可能。共有2+3+2=7种。

2.列出1中所有情况。

队首 队中 队尾
max min -
max - min
min max -
- max,min -
- max min
min - max
- min max

分析交换算法

以先将最小值归位(最小值和第一个数交换),再将最大值归位(最大值和最后一个数交换)进行分析,注意是按位置操作。

队首 队中 队尾 可行性 不可行的原因
max min - × 第一次把最小值换到了第一位,第二次又把最小值误当做最大值换到了最后一位
max - min × 同上
min max - -
- max,min - -
- max min -
min - max -
- min max -

通过对上面的分析,发现最大值在第一位的时候交换算法不可行,原因是这时的交换算法的第一步破坏了最大值和最小值的位置。对第一种情况,先将最大值归位,再将最小值归位;对第二种情况,执行将最小值归位即可。(这只是一种处理方式,仅作参考)。

回顾总结(问题核心)

题目中要使用到两次交换,第一次交换会不会影响第二次交换是问题的关键,算法只要不让第一次交换影响到第二次交换即可,或者不让第二次交换受到第一次交换的影响。

算法思路分析描述版:

将最小值归位,再将最大值归位。第一次的执行肯定是可以将最小值移到第一位的,所以不用考虑最小值(位置)。而最大值只有在第一位的时候才会受到第一次交换的影响。最大值在第一位有两种情况,需要分别进行特殊处理。

队首 队中 队尾 可行性 不可行的原因
max min - × 第一次把最小值换到了第一位,第二次又把最小值误当做最大值换到了最后一位
max - min × 同上

对第一种情况,先将最大值归位,再将最小值归位;对第二种情况,执行将最小值归位即可。

三、编写代码


#include <stdio.h>
#include <stdlib.h>
#define MAXN 10
int data[MAXN];
void get_data(){
    int i;
    for(i=0;i<MAXN;i++) scanf("%d",data+i);
}
void analysis(){
    int min=data[0],max=data[0];
    int mini=0,maxi=0;
    int temp;
    for(int i=1;i<MAXN;i++){
        if(data[i]<min){
            min=data[i];
            mini=i;
        }
        if(data[i]>max){
            max=data[i];
            maxi=i;
        }
    }
    if(maxi==mini) ; //nothing to do
    else if((maxi==0)&&(min!=MAXN-1)){
        temp=data[MAXN-1];
        data[MAXN-1]=data[maxi];
        data[maxi]=temp;
        temp=data[0];
        data[0]=data[mini];
        data[mini]=temp;
    }
    else if((maxi==0)&&(min==MAXN-1)){
        temp=data[0];
        data[0]=data[mini];
        data[mini]=temp;
    }
    else{
        temp=data[0];
        data[0]=data[mini];
        data[mini]=temp;
        temp=data[MAXN-1];
        data[MAXN-1]=data[maxi];
        data[maxi]=temp;
    }
}
void print_data(){
    for(int i=0;i<MAXN;i++) printf("%d ",data[i]);
}
int main()
{
    get_data();
    analysis();
    print_data();
    return 0;
}

四、出现问题

1.把max的位置maxi打错,打成了max,少打了一个i。

2.把宏定义MAXN当做数组的最后一个元素,实际应该是MAXN-1,MAXN是数组的大小。

3.把mini==maxi写成mini=maxi,等于操作符写成赋值操作符。

4.最大值在首,最小值在尾的情况解决方法出现错误,原来使用把最大值先归位、再把最小值归位的错误算法,实际上是两次互相交换,不起作用。但是提交到系统通过了,说明系统没有这种形式的测试用例。不过还是不能侥幸。

总结

本片文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!

--结束END--

本文标题: C语言--数字交换题目详解

本文链接: https://lsjlt.com/news/133911.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言--数字交换题目详解
    目录一、题目分析二、算法分析和设计心路历程位置分析分析交换算法回顾总结(问题核心)三、编写代码四、出现问题总结一、题目分析 大致题意就是通过交换把最小的数放到最前面,最大的数放最后...
    99+
    2024-04-02
  • C语言字符串替换:字符,字符串,字符数组详解
    目录案例描述案例分析必备知识1,字符数组(1)字符数组的定义(2)字符数组的初始化2,字符串概念(1)字符串的概念(2)用字符初始化字符数组(3)获取字符串的长度3,字符串与指针4,...
    99+
    2024-04-02
  • C语言字符串替换:字符,字符串,字符数组详解
    在C语言中,字符串是由字符数组表示的。一个字符串是一个以null字符('\0')结尾的字符数组。字符替换:要替换字符串中的某个字符,...
    99+
    2023-08-15
    C语言
  • Go语言题解LeetCode888公平糖果交换示例详解
    目录一 描述二 分析三 答案一 描述 888. 公平的糖果交换 - 力扣(LeetCode) (leetcode-cn.com) 爱丽丝和鲍勃拥有不同总数量的糖果。给你两个数组 ...
    99+
    2022-12-28
    Go题解公平糖果交换 Go LeetCode题解
  • C语言字符串数组详解
    C语言字符串数组 字符串是连续的字符序列,最后以空字符'\0'作为终止符。一个字符串的长度指所有字符的数量,但不包括终止符。在 C 语言中,没有字符串类型,自然也就没有运算符以字符串...
    99+
    2024-04-02
  • C语言练习之数组中素数交换
    目录题目要求总结题目要求 (1)在主函数中创建数组num,使用测试数据{108 4 19 7 23 66 49 13 33 35}对其初始化; (2)定义change函数,将num数...
    99+
    2024-04-02
  • C语言:传值与传址交换整数
    目录传值调用传址调用总结传值调用 要想交换两个整数的值,我们可以自定义一个函数,来实现这个过程。具体代码如下: #include <stdio.h> void Sw...
    99+
    2024-04-02
  • C语言怎么交换两个数的值
    本文小编为大家详细介绍“C语言怎么交换两个数的值”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言怎么交换两个数的值”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。使用临时变量以下实例演示了交换两个浮点数的值。...
    99+
    2023-06-17
  • C语言长字符串的换行方法详解
    目录1.长字符串示例2.书写长字符串的换行方法方法一:利用双引号对长字符串进行换行方法二:利用反斜杠对长字符串进行换行3.总结在编写C程序时,如果想要打印某个字符串,而字符串的内容比...
    99+
    2024-04-02
  • C语言字符串替换空格实例详解
    目录一、题目描述二、思路分析三、整体代码总结一、题目描述 请实现一个函数,把字符串 s 中的每个空格替换成"%20"。 示例: 输入:s = "We a...
    99+
    2024-04-02
  • 详解C语言内核字符串转换方法
    在内核编程中字符串有两种格式ANSI_STRING与UNICODE_STRING,这两种格式是微软推出的安全版本的字符串结构体,也是微软推荐使用的格式,通常情况下ANSI_STRIN...
    99+
    2024-04-02
  • C语言字符函数与字符串函数详解
    目录本章重点前言1.strlen函数注意点1注意点22.strcpy注意点1:注意点2:注意点3:注意点4:总结本章重点 重点介绍处理字符和字符串的库函数的使用和注意事项 1.求字符...
    99+
    2024-04-02
  • c语言中怎么交换两个数的值
    在C语言中,可以使用几种方法来交换两个数的值。1. 使用第三个变量:```cint a = 5;int b = 10;int temp;temp = a;a = b;b = temp;```2. 使用加减法:```cint a = 5;...
    99+
    2023-08-11
    c语言
  • C语言详解Z字形变换排列的实现
    目录方法一方法二题目链接:Z 字形变换 方法一 ——找规律模拟数组 题目要求构造一个从左到右的Z型矩阵。 通过分析,可以看出这个Z型矩阵的特点 Z型矩阵就...
    99+
    2024-04-02
  • C语言字符函数isalnum()和iscntrl()详解
      isalnum() 函数用于检查所传的字符是否是字母或者十进制数字。它的函数原型如下: _CRTIMP int __cdecl isalnum(int _...
    99+
    2024-04-02
  • 详解C语言实现猜数字游戏
    目录一:猜数字游戏基本介绍&对程序预期二:程序设计思路1.总体思路:2.菜单部分函数:3.游戏部分函数4.主函数部分5.代码主体三:总结前言:本文主要讲解以c语言编写猜数字游...
    99+
    2024-04-02
  • C语言main()函数的参数问题详解
    #include<stdio.h> void main(int argc, char* argv[]) { while (argc > 1) { ++a...
    99+
    2024-04-02
  • C语言转义字符详解
    ####1.认识转义字符 所有的ASCII码都可以用“\”加数字(一般是8进制数字)来表示。而C中定义了一些字母前加""来表示常见的那些不能显示的ASCII字符,如\0,\t,\n...
    99+
    2024-04-02
  • C语言递归在实践题目中应用详解
    目录递归知识点题目第一题第二题第三题第四题第五题第六题第七题递归知识点 递归概念:程序调用自身的编程技巧称为递归( recursion)。 递归做为一种算法在程序设计语言中广泛应用。...
    99+
    2024-04-02
  • c语言如何把字符转换成数字
    在C语言中,可以使用以下几种方法将字符转换为数字: 使用ASCII码:C语言中的字符是以ASCII码表示的,可以通过ASCII码将...
    99+
    2023-10-22
    c语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作