【C语言】剔除最大最小值后,计算数组元素的平均值
双11也不能阻挡我学习的心! [TOC] 问题引入 题目内容: 定义一个含10个整型元素的一维数组,从键盘上输入10个元素值,求去掉最大值和最小值之后的元素平均值. 输入格式: 用循环控制依次输入10个元素值,scanf语句中的格式控制串为: “%d” 输出格式: 输出平均值, printf中的格式控制串为 “%lf\n” 输入样例: 12 3 4 5 6 2 4 6 4 3 输出样例: 13.833333 理解1一般人看到这种题目,下意识会认为是去掉一个最大值一个最小值,再计算数组其他元素的最大值 毕竟很多体育赛事都是这么计算选手的得分的 实际上这道题并不是这么要求的,这点我们后面再提 先来看看如何去掉数组中的一个最大值、一个最小值吧! 去除一个最大/最小值先理清思路 需要找到数组中的最大值和最小值 在计算平均值的时候需要剔除这两个值 想清楚这两点后,方法就很明确了 之前我写过一篇博客,有关如何查找数组中最大值的 [链接] 这里我们就能用上那个博客里面的方法,不过是以自定义函数的方式实现 123456789101112131415161718int...
【C语言】如何将输入的数字逆序打印
这个问题是我在做学校的作业时候看到的。只隐约有印象讲过,但是忘记了怎么操作。听同学的点通才回想起来,特此写个博客留记 [toc] 逆序打印目的:输入“789”,打印“987” 注:本博客的数字逆序只涉及 十进制 代码实现有两种方式:1.利用if语句进行大小判断,直到选出从大到小的数字排序这个方法十分复杂,稍不留意就会弄错,所以在实际应用中不推荐这样操作这里就不赘述具体代码了。(才不是懒,压根没试过)2.使用%10的方法直接打印代码如下: 123456789101112#include <stdio.h>int main(){ int a = 0; scanf("%d", &a); printf("%d", a % 10); printf("%d", a/10 % 10); printf("%d", a/100 % 10); return...
【C语言】童年经典游戏-三字棋
@toc 问题引入 - 什么是三子棋?想必大家儿时都玩过:#字棋 如图,即一个3x3的格子,玩家需要在横、竖、斜三条线上布下自己的棋子 先连成一条线上3个棋子的玩家获胜 如果格子填满后还未有胜者,即为平局 今天就让我们用c语言代码来完成一个基础的三子棋小游戏 涉及知识点: 二维数组、循环语句、自定义函数、自定义头文件 关联博客:扫雷游戏 自定义头文件本次三子棋代码实现中,我们需要使用到自定义头文件 使用自定义函数前,需要先对函数进行声明 头文件就是一堆声明的集合 问:为什么不把函数声明直接main函数前面? 答:因为这样更方便团队进行同一个项目的分工制作 如何创建自定义头文件? 在vs编译器的“解决资源管理器”里,我们能看到头文件的文件夹 右键它,新建项 选择头文件进行新建,后缀是.h 创建完后,我们可以在另外一个源文件中引用头文件 1#include...
【C语言】用递归和非递归,求第n个斐波那契数
[toc] 问题引入 - 什么是斐波那契数列?斐波那契数列中,第n项为n-1和n-2项之和 1,1,2,3,5,8,13,21,34,55…… 这个数列非常经典,经常用于编程语言初学者的练习 接下来让我们用非递归和递归两种方式来实现这个数列 并了解两种方法的优缺点! 1.非递归方法(迭代)什么是迭代? 迭代其实和循环的意义差不多(个人理解) 我们计算斐波那契数列的时候,需要从第一项和第二项1、1开始计算 没后一项数字都是前两项数字之和 这样我们就可以利用循环,从第一项开始不断相加,再使其中一个加数等于得到的和 以此迭代,就能得到我们需要的第n个数字 代码实现12345678910111213141516171819202122232425262728293031#include<stdio.h>//非递归int fo1(int a){ int tmp = 0; int num1 = 1; int num2 =1; if (a < 3) //前两项都为1 { return...
【leetcode】001.两数之和(C语言,超详细)
这是初学C时候写的题解,可能有思维漏洞,后面重新刷题的时候会更改! PS:已重新更正并添加了C++的哈希解法 [toc] 1 题目来源两数之和 leetcode-001 如下图所示 右侧给出了题目的基本模板 1234567/** * Note: The returned array must be malloced, assume caller calls free(). */int* twoSum(int* nums, int numsSize, int target, int* returnSize){} 2...
【C语言】如何判断素数
如何判断素数 题目要求:输出100-200的素数 首先我们要知道什么是素数(质数),以防有人忘记(比如刚学开始学c的我就忘记了) 素数(质数)只能被1和它自己整除 7只能被1和7整除,是素数 9能被3整除,不是素数 方法1—试除法12345678910111213141516171819202122232425#include<stdio.h>int main(){ int i=0; int count=0; for(i=100;i<=200;i++) { int j=0; for(j=2;j<i;j++) { if(i%j==0)//i可以整除j,i不是素数 { break; } } if(j==i)//i只能整除它自己,是素数 { ...
【C语言】验证哥德巴赫猜想
问题来源这是学校的一个作业,原题如下 题目先给出了哥德巴赫猜想的背景知识(我还真不知道) 2000以内的正偶数都能分解成两个质数(素数)之和 题目要求下面来梳理一下题目的要求: 输出样式为a=b+c,使用%4d=%4d+%4d输出 每行输出4个,每行最后一个输出无空格 每个偶数只需要一个结果即可(后续较大的偶数有很多种解) 弄懂了题目要求,下面就来一步一步写代码 如何判断素数?在上篇博客里面提到了如何判断素数==>【链接】,这里不再赘述 我们需要搞定的是判断是那两个素数b、c相加等于我们需要的那个数a 因为需要多次判断,这里我们使用自定义函数 12345678910111213141516int SuShu(int a){ if (a == 2) { return 1; } int j = 0; for(j = 2; j <=sqrt(a); j++) { if (a % j == 0) { return 0; } } return...
【C语言】printf函数的执行顺序,涉及函数传参
问题产生偶然在c语言学习交流群看到了这么一串让人费解的代码 1234567891011#include <stdio.h>int main(){ int i = 0; int j = 0; scanf("%d", &i); j = -i++; printf("%d %d %d", i, j, i++); return 0;} 这里让我疑惑的是,为什么打印的第一个i是6而不是5? printf语句的执行顺序这里要涉及到一个之前我并不清楚的知识点 123scanf("%d", &i);j = -i++;printf("%d %d %d", i, j, i++); 按照以往我的理解,代码的运行顺序是这样的 1.用scanf将数字赋值给i 2.将-i赋值给j,然后i++...
【C语言】简单的printf递归
简单的Print递归 说句题外话,很多时候单词我是认识的,但是如果它全大写了,我总要反应老一会才能想出来它的意思 有和我一样的人吗? 今天的c语言课讲到了一道非常经典的递归题目 代码如下: 12345678910111213141516#include <stdio.h>void Print(int n){ if (n > 9) Print(n / 10); printf("%d ", n % 10);}int main(){ int num = 0; scanf("%d", &num); Print(num); return 0;} 结果如下 运行顺序谈到递归的时候,最重要的就是要弄明白它究竟是怎么运行的 老师上课讲的方法非常直观的表示了它的运算顺序 这里我用粘贴代码块的方式来展示 刚开始执行的是scanf输入,这里不再赘述 123456void Print(int n){ if (n > 9) Print(n /...