【C/PTA —— 10.函数1(课外实践)】

C/PTA ------ 10.函数1(课外实践)

  • 一.函数题
    • [6-1 符号函数](#6-1 符号函数)
    • [6-2 求排列数](#6-2 求排列数)
    • [6-3 求一个大于10的n位整数w的后n-1位的数,并作为函数值返回。](#6-3 求一个大于10的n位整数w的后n-1位的数,并作为函数值返回。)
    • [6-4 其右上三角(含主对角线)元素之和。](#6-4 其右上三角(含主对角线)元素之和。)
    • [6-5 字符串比较](#6-5 字符串比较)
    • [6-6 使用函数求素数和](#6-6 使用函数求素数和)
    • [6-7 使用函数输出水仙花数](#6-7 使用函数输出水仙花数)
  • 二.编程题
    • [7-1 寻找自守数](#7-1 寻找自守数)

一.函数题

6-1 符号函数

c 复制代码
int sign(int x)
{
    if (x > 0)
        return 1;
    else if (x == 0)
        return 0;
    else
        return -1;
}

6-2 求排列数

c 复制代码
double fact(int n)
{
    long long ret = 1;
    for (long long i = 1; i <= n; i++)
    {
        ret =ret * i;
    }
    return ret;
}

6-3 求一个大于10的n位整数w的后n-1位的数,并作为函数值返回。

c 复制代码
#include<math.h>
int fun(int w)
{
	int sum = 0;
	int count = 0;
	int num = w;
	while (num)
	{
		num /= 10;
		count++;
	}
	sum = w % (int) (pow(10, count - 1));
	return sum;
}

6-4 其右上三角(含主对角线)元素之和。

c 复制代码
int fun(int a[3][3])
{
    int sum1 = 0, sum2 = 0;
    for (int i = 0; i < 3; i++)
    {
        for (int j = i; j < 3; j++)
        {
            sum1 += a[i][j];
        }
    }
    return sum1;
} 

6-5 字符串比较

c 复制代码
int fun(char a[], char b[])
{
	if (strcmp(a, b) < 0)
		return -1;
	else if (strcmp(a, b) > 0)
		return 1;
	else
		return strcmp(a, b);
}

6-6 使用函数求素数和

c 复制代码
int prime(int p)
{
    int count = 0;
    if(p==1)
        return 0;
    for (int i = 2; i <= p; i++)
    {
        if (p % i == 0)
            count++;
    }
    if (count == 1)
        return 1;
    else
        return 0;
}
int PrimeSum(int m, int n)
{
    int sum = 0;
    for (int i = (m<=n?m:n); i <= (n>=m?n:m); i++)
    {
        if (prime(i) == 1)
            sum += i;
    }
    return sum;
}

6-7 使用函数输出水仙花数

c 复制代码
#include<math.h>
int narcissistic(int number)
{
    int count = 0;
    int sum1 = 0;
    int num = number;
    while (number)
    {
        number /= 10;
        count++;
    }
    int sum = 0;
    number = num;
    while (number)
    {
        sum1 = number % 10;
        sum += (int)(pow(sum1, count));
        number /= 10;
        sum1 = 0;
    }
    if (num == sum)
        return 1;
    else
        return 0;
}
void PrintN(int m, int n)
{
    for (int i = (m <= n ? m : n)+1; i < (n >= m ? n : m); i++)
    {
        if (narcissistic(i) == 1)
        {
            printf("%d\n", i);
        }
    }
} 

二.编程题

7-1 寻找自守数

c 复制代码
#include<stdio.h>
int ZISHOUnum(int p)
{
	int num = 0, count = 0;
	num = p * p;
	while (p != 0)
	{
		if (p % 10 != num % 10)
			return 0;
		p /= 10;
		num /= 10;
	}
	return 1;
}

int main()
{
	int n = 0, m = 0;
	int count = 0;
	scanf("%d %d", &n, &m);
	for (int i = n; i <= m; i++)
	{
		if (ZISHOUnum(i))
		{
			count++;
			printf("%d\n", i);
		}
			
	}
	if (count == 0)
	{
		printf("None\n");
	}
	return 0;
}
相关推荐
py有趣8 小时前
力扣热门100题之不同路径
算法·leetcode
_日拱一卒8 小时前
LeetCode:25K个一组翻转链表
算法·leetcode·链表
啊哦呃咦唔鱼8 小时前
LeetCodehot100-394 字符串解码
算法
小欣加油9 小时前
leetcode2078 两栋颜色不同且距离最远的房子
数据结构·c++·算法·leetcode·职场和发展
我真不是小鱼9 小时前
cpp刷题打卡记录30——轮转数组 & 螺旋矩阵 & 搜索二维矩阵II
数据结构·c++·算法·leetcode
三品吉他手会点灯10 小时前
STM32 VSCode 开发-C/C++的环境配置中,找不到C/C++: Edit Configurations选项
c语言·c++·vscode·stm32·单片机·嵌入式硬件·编辑器
逻辑驱动的ken10 小时前
Java高频面试考点场景题09
java·开发语言·数据库·算法·oracle·哈希算法·散列表
帅小伙―苏10 小时前
力扣42接雨水
前端·算法·leetcode
AI科技星11 小时前
精细结构常数α的几何本源:从第一性原理的求导证明、量纲分析与全域验证
算法·机器学习·数学建模·数据挖掘·量子计算
三品吉他手会点灯11 小时前
C语言学习笔记 - 1.C概述 - 本讲内容概述
c语言·笔记·学习