【C语言】题集 of ⑥

简介: 是考察你对循环的理解,本道题目要特别注意下循环当中的表达式,以及创建个sum总值用于每次循环i相乘sum,直到循环结束打印sum。

✨第二十六题→实现N的阶层(分别实现while、for)✨

首先N的阶层实际上就是假设5的阶层就是1x2x3x4x5这种就叫做是5的阶层,本题要求用while循环和for循环求阶层这道题目实际上就是考察你对循环的理解,本道题目要特别注意下循环当中的表达式,以及创建个sum总值用于每次循环i相乘sum,直到循环结束打印sum。

✨第二十七题→在一个有序的数组中查找具体某个数字k(二分查找)✨

二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。

二分查找的基本思想是将n个元素分成大致相等的两部分,取a[n/2]与x做比较,如果x=a[n/2],则找到x,算法中止;如果x<a[n/2],则只要在数组a的左半部分继续搜索x,如果x>a[n/2],则只要在数组a的右半部搜索x。最后,当我们找到元素进行打印再跳出。如果没找到就跳出循环。

✨第二十八题→使用for循环语句显示10个随机数!打印产生随机数1~100~✨

在C语言中,我们一般使用 <stdlib.h> 头文件中的 rand() 函数来生成随机数,它的用法为:

int rand (void);那么上述程序当中需要我们生成随机数是1~100这个怎么去生成,实际上很容易。我们直到rand()生成的最大值是0~32768,那么在本题目当中我们需要生成1~100也就是说我们需要产生一定随机值的方法,这个时候就可以用到取模运算符。示例如下代码所示:

int ret = rand() % 10;    //产生0~9的随机数 - 注意10会被整除

当然如果你这里取模100只是会产生0~99的数字,你必须还要+1才行这样就是1~100范围之间的数字了刚好吻合题目要求。所以,在本道题目实际上就是用到取模运算符来解决这个问题。

使用 <time.h> 头文件中的 time() 函数即可得到当前的时间(精确到秒),就像下面这样:

srand((unsigned)time(NULL));通常只需要引用一次即可!

✨第二十九题→打印出金字塔✨

打印金字塔无非就是用for循环进行嵌套,当我们输入数字5的时候,我们来假设它的一个运行结果来看看这样有利于我们解题↓

    *
   ***
  ***** 
 *******
*********

上述就是输入数字5,所打印出的金字塔。从这个运行结果我们再来做题就好办多了。 如果你不理解它的运行步骤可以多去调试,调试真的能帮助你解决很多问题,尤其是你刚学C语言的人或者是初学者,那怕是大牛阿,都是需要调试的。可以说一个人写代码的时间可能只有百分之30~40,而大多数人写代码调试的时间却有百分之60~70了。

✨第三十题→输入两个数字,求它们的最大公约数✨

最大公因数,也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个。

a,b的最大公约数记为(a,b),同样的,a,b,c的最大公约数记为(a,b,c),多个整数的最大公约数也有同样的记号。求最大公约数有多种方法,常见的有质因数分解法、短除法、辗转相除法、更相减损法。与最大公约数相对应的概念是最小公倍数,a,b的最小公倍数记为[a,b]。

这个也是在数学当中我们会经常用到短除法。

✨第二十六题代码✨

for循环的使用↓

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(void)
{
  int i = 0;
  int j = 0;
  int sum = 1;
  printf("请输入数字:");
  scanf("%d", &j);
  for (i = 1; i <= j; i++)
  {
    sum = sum * i;//sum 实现N的阶乘之和
  }
  printf("sum = %d\n", sum);
  return 0;
}

while循环的使用↓

🖊运行结果

可能运行结果 👇

请输入数字:5

sum = 120


✨第二十七题代码✨

#include<stdio.h>
int main(void)
{
  int k = 7;
  int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
  int sz = sizeof(arr) / sizeof(arr[0]); 
  int left = 0;                  
  int right = sz - 1;           
  while (left <= right)        
  {
    int mid = (left + right) / 2;    
    if (arr[mid] < k)
    {
      left = mid + 1;
    }
    else if (arr[mid] > k)
    {
      right = mid - 1;
    }
    else
    {
      printf("找到了,数组下标:%d,元素%d\n", mid,arr[mid]);
      break;
    }
  }
  if (left > right)
  {
    printf("找不到!\n");
  }
  return 0;
}

🖊运行结果

找到了,数组下标6,元素7

✨第二十八题代码✨

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define NUM 10
int main(void)
{
  int i = 1;
  srand((unsigned)time(NULL));
  for (i = 1; i <= NUM; i++)
  {
    int ret = rand() % 100 + 1;
    printf("第%-2d次:数字-->%d\n", i, ret);
  }
  return 0;
}

}

🖊运行结果

第1 次 : 数字-->13

第2 次 : 数字-->74

第3 次 : 数字-->71

第4 次 : 数字-->42

第5 次 : 数字-->23

第6 次 : 数字-->10

第7 次 : 数字-->10

第8 次 : 数字-->47

第9 次 : 数字-->11

第10次: 数字-->46

✨第二十九题代码✨

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(void)
{
  int i, j, k;
  int input;
  printf("请输入数字:-->");
  scanf("%d", &input);
  for (i = 1; i <= input; i++)
  {
    //思路:空格 & 打印 *
    for (j = 1; j <= input - i; j++)
    {
      printf(" ");
    }
    for (k = 1; k <= 2 * i - 1; k++)
    {
      printf("*");
    }
    printf("\n");
  }
  return 0;
}

🖊运行结果

请输入数字:-->5

    *
   ***
  ***** 
 *******
*********

✨第三十题代码✨

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
int main(void)
{
  int a = 0, b = 0, t = 0;
  printf("请输入两个数字:");
  scanf("%d %d", &a, &b);
  while (t = a%b)
  {
    a = b;
    b = t;
  }
    //假设:a = 10、b = 20
    //t = 10 
  printf("|--------------------|\n");
  printf("|两个数的最大公约数:%d|\n",b);
  printf("|--------------------|\n");
  return 0;
}

🖊运行结果

请输入两个数字:10 20

两个数的最大公约数:10

目录
相关文章
|
8月前
|
存储 程序员 C语言
C语言进1
C语言进1
|
5月前
|
存储 编译器 C语言
十一:《初学C语言》— 操作符详解(上)
【8月更文挑战第12天】本篇文章讲解了二进制与非二进制的转换;原码反码和补码;移位操作符及位操作符,并附上多个教学代码及代码练习示例
68 0
十一:《初学C语言》—  操作符详解(上)
|
Java 编译器 Linux
第一个C语言程序(认识C语言的第一步)
第一个C语言程序(认识C语言的第一步)
55 0
|
存储 编译器 C语言
【C语言】 详谈指针
【C语言】 详谈指针
114 0
|
C语言 C++ Perl
【初始C语言】/*C语言初阶指针通俗详解*/
【初始C语言】/*C语言初阶指针通俗详解*/
98 0
【初始C语言】/*C语言初阶指针通俗详解*/
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)(三)
🗽初阶指针请点击此跳转 https://blog.csdn.net/DerrickWestbrook/article/details/117787490. 指针的主题,在上述链接文章中已经解释过了,我们已经知道了指针的概念: 指针就是个变量,用来存放地址,地址唯一标识一块内存空间。 指针的大小是固定的4/8个字节(32位平台/64位平台)。 指针是有类型的,指针的类型决定了指针的±整数的步长,指针解引用操作的时候的权限。 在本篇文章将继续讲解质指针的高级主题
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)(三)
|
存储 网络协议 C语言
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)(一)
🗽初阶指针请点击此跳转 https://blog.csdn.net/DerrickWestbrook/article/details/117787490. 指针的主题,在上述链接文章中已经解释过了,我们已经知道了指针的概念: 指针就是个变量,用来存放地址,地址唯一标识一块内存空间。 指针的大小是固定的4/8个字节(32位平台/64位平台)。 指针是有类型的,指针的类型决定了指针的±整数的步长,指针解引用操作的时候的权限。 在本篇文章将继续讲解质指针的高级主题
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)(一)
|
存储 网络协议 C语言
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)
【C语言】C语言之深入指针进阶(建议收藏以备不时之需)(二)
🗽初阶指针请点击此跳转 https://blog.csdn.net/DerrickWestbrook/article/details/117787490. 指针的主题,在上述链接文章中已经解释过了,我们已经知道了指针的概念: 指针就是个变量,用来存放地址,地址唯一标识一块内存空间。 指针的大小是固定的4/8个字节(32位平台/64位平台)。 指针是有类型的,指针的类型决定了指针的±整数的步长,指针解引用操作的时候的权限。 在本篇文章将继续讲解质指针的高级主题
|
算法 物联网 数据安全/隐私保护
【C语言】题集 of ⑤
程序调用自身的编程技巧称为递归。递归作为一种算法在程序设计语言中是广泛应用的。一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题转换位一个与原问题相似的规模较小的问题来去进行求解,递归策略只需少了的程序就可以描述出解题的
170 0

热门文章

最新文章

下一篇
开通oss服务