手写C语言之函数操作-判断100-200内的素数-判断是否是闰年-二分查找函数实现-传址调用自增长函数实现(14)

简介: 手写C语言之函数操作-判断100-200内的素数-判断是否是闰年-二分查找函数实现-传址调用自增长函数实现

函数操作应用题

  1. 写一个函数可以判断一个数是不是素数。
  2. 写一个函数判断一年是不是闰年。
  3. 写一个函数,实现一个整形有序数组的二分查找。
  4. 写一个函数,每调用一次这个函数,就会将 num 的值增加1。

写一个函数可以判断一个数是不是素数。


#include <stdio.h>
//定义函数名,注意因为有返回值,所以需要类型,其次传入一个整型变量
int is_prime(int x) {
  int j = 0;
  //素数的判断规则,从2到x-1进行尝试
  for (j = 2; j < x; j++) {
    if (x % j == 0) {
      //取模操作符之后如果是0,就不是素数
      return 0;
    }
  }
  return 1;
}
int main() {
  int i = 0;
  int count = 0;
  for (i = 100; i <= 200; i++) {
    //调用判断函数
    if (is_prime(i) == 1) {
      printf("%d\t", i);
      count++;
    }
  }
  printf("一共有%d个素数!", count);
  return 0;
}


image.png

注意,不建议将打印信息放入函数,因为函数是一个实现的功能,独立的,灵活性的!

为了更加的优化代码可以将x换成sqrt(x),这也是素数函数的设置的一个优化点

写一个函数判断一年是不是闰年。

#include <stdio.h>
int is_leap_yar(int x) {
  if (((x % 4 == 0) && (x % 100 != 0)) || (x % 400 == 0)) {
    return 1;
  }
  else {
    return 0;
  }
}
int main() {
  int y = 0;
  for (y = 1000; y <= 2000; y++) {
    //闰年函数的调用
    if (is_leap_yar(y) == 1) {
      printf("%d ", y);
    }
  }
  return 0;
}

注意,判断是否是闰年的规则是,该年份能被4整除但是不能被100整除(同时满足),或者可以被400整除!

写一个函数,实现一个整形有序数组的二分查找。

这个代码,我们前期已经实现过了!

#include <stdio.h>
int serch(int a[], int k, int sz) {
  int left = 0;
  int right = sz - 1;
  while (left <= right)
  {
    int mid = (left + right) / 2;
    if (a[mid] > k) {
      right = mid - 1;
    }
    else if (a[mid] < k) {
      left = mid + 1;
    }
    else {
      return mid;
    }
  }
  return -1;
}
int main() {
  int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
  int key = 7;
  //找到就返回位置下标,找不到就返回-1
  int sz = sizeof(arr) / sizeof(arr[0]);
  int ret = serch(arr, key, sz);
  if (-1 == ret) {
    printf("找不到\n");
  }
  else {
    printf("找到了,位置下标是:%d", ret);
  }
  return 0;
}


数组传入参数,形参也要设置为数组类型的参数


数组传参,实际传递的不是数组的本身,而是传进去数组的首地址

image.png


写一个函数,每调用一次这个函数,就会将 num 的值增加1

目前,我们只学习到函数,下一个文章,我们讲到递归的时候,也会根据其语法进行深入的剖析的。


这里需要注意的是,我们传入的参数是一个指针变量,也就是空间地址,为什么呢?原因是我们需要通过函数内部的功能进行对外部的变量进行改变,所以我们需要利用地址进行操作,所以这个函数我们传入的是一个地址变量!


#include <stdio.h>
void Add(int* p) {
  (*p)++;//对其进行解引用,然后递增
}
int main() {
  int num = 0;
  Add(&num);
  printf("%d  ", num);
  Add(&num);
  printf("%d  ", num);
  Add(&num);
  printf("%d  ", num);
  Add(&num);
  printf("%d  ", num);
  return 0;
}


image.png

相关文章
|
17天前
|
存储 C语言 开发者
【C语言】字符串操作函数详解
这些字符串操作函数在C语言中提供了强大的功能,帮助开发者有效地处理字符串数据。通过对每个函数的详细讲解、示例代码和表格说明,可以更好地理解如何使用这些函数进行各种字符串操作。如果在实际编程中遇到特定的字符串处理需求,可以参考这些函数和示例,灵活运用。
39 10
|
17天前
|
存储 程序员 C语言
【C语言】文件操作函数详解
C语言提供了一组标准库函数来处理文件操作,这些函数定义在 `<stdio.h>` 头文件中。文件操作包括文件的打开、读写、关闭以及文件属性的查询等。以下是常用文件操作函数的详细讲解,包括函数原型、参数说明、返回值说明、示例代码和表格汇总。
41 9
|
17天前
|
存储 Unix Serverless
【C语言】常用函数汇总表
本文总结了C语言中常用的函数,涵盖输入/输出、字符串操作、内存管理、数学运算、时间处理、文件操作及布尔类型等多个方面。每类函数均以表格形式列出其功能和使用示例,便于快速查阅和学习。通过综合示例代码,展示了这些函数的实际应用,帮助读者更好地理解和掌握C语言的基本功能和标准库函数的使用方法。感谢阅读,希望对你有所帮助!
31 8
|
17天前
|
C语言 开发者
【C语言】数学函数详解
在C语言中,数学函数是由标准库 `math.h` 提供的。使用这些函数时,需要包含 `#include <math.h>` 头文件。以下是一些常用的数学函数的详细讲解,包括函数原型、参数说明、返回值说明以及示例代码和表格汇总。
40 6
|
17天前
|
存储 C语言
【C语言】输入/输出函数详解
在C语言中,输入/输出操作是通过标准库函数来实现的。这些函数分为两类:标准输入输出函数和文件输入输出函数。
102 6
|
17天前
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
47 6
|
17天前
|
C语言 开发者
【C语言】断言函数 -《深入解析C语言调试利器 !》
断言(assert)是一种调试工具,用于在程序运行时检查某些条件是否成立。如果条件不成立,断言会触发错误,并通常会终止程序的执行。断言有助于在开发和测试阶段捕捉逻辑错误。
27 5
|
7月前
|
存储 C语言
C 语言函数完全指南:创建、调用、参数传递、返回值解析
函数是一段代码块,只有在被调用时才会运行。 您可以将数据(称为参数)传递给函数。 函数用于执行某些操作,它们对于重用代码很重要:定义一次代码,并多次使用。
222 3
|
2月前
|
C语言
C语言函数返回值详解
本文详细解析了C语言中函数返回值的概念与应用。从函数的基本定义入手,深入探讨了不同类型返回值的作用及意义,并提供了实用的编程示例,帮助读者更好地理解和使用函数返回值。通过本文,你将掌握如何有效利用返回值优化代码结构与功能实现。
|
6月前
|
存储 C语言
C语言的函数返回值和指针
C|函数返回值(区分各类值)和指针(区分各类存储空间)的细节