C语言习题整理①

news2024/10/6 11:47:34

一些C语言习题的整理。

目录

一、判断质数

二、判断回文数

三、判断水仙花数

四、输出乘法表

五、输出杨辉三角


一、判断质数

质数是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。质数又称素数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数)。质数的个数是无穷的。

这道题思路不难,令用户输入数字num,设置一个cnt用来计数,在循环中令i从2开始递增,如果num对i模为0证明可以被整除,则cnt++,如果cnt最终仍旧为0说明没有数可以整除它,该数字就是质数。

代码实现:

#include<stdio.h>
int main(void)
{
    int cnt,num;
    int i;
    printf("plz enter the number, enter q to quit:\n");

    while(scanf("%0d",&num) != 0)
    {
        cnt = 0;
        for(i=2;i<num;i++)
        {
            if(num%i == 0)
                cnt++;
        }

        if(cnt)
            printf("%0d is not prime number.\n",num);
        else
            printf("%0d is prime number.\n",num);

        printf("plz enter next number, enter q to quit:\n");
    }

    return 0;
}

运行结果:

也可以变化一下,直接显示输入数字内含有的所有质数:

#include<stdio.h>
int main(void)
{
    int cnt,num;
    int i,j;
    printf("plz enter the number, enter q to quit:\n");

    while(scanf("%0d",&num) != 0)
    {
        printf("num is %0d.\n",num);
        for(i=2;i<=num;i++)
        {
            cnt = 0;
            for(j=2;j<i;j++)
            {
                if(i%j == 0)
                    cnt++;
            }
            if(!cnt)
                printf("%0d is prime number.\n",i);
        }
        printf("plz enter next number, enter q to quit:\n");
    }

    return 0;
}

运行结果:

二、判断回文数

回文数就是正向排列和反向排列是一样的数字。设n是一任意自然数,若将n的各位数字反向排列所得自然数n1与n相等,则称n为一回文数。例如,若n=1234321,那么n就是回文数。

首先回文数必须要大于100,否则没有意义。对于1000以内的数字,可以通过判断数字的百位数和个位数是否相等,从而列出所有的回文数。代码实现:

int main(void)
{
    int num;
    int a,b,c,i;

    printf("plz enter the number, q to quit:\n");
    while(scanf("%0d",&num) != 0)
    {
        printf("answer is:\n");
        for(i=100;i<=num;i++)
        {
            c = i%10; 
            b = (i/10)%10;
            a = i/100;

            if(a == c)
                printf("%5d",i);
        }
        printf("\n");
        printf("plz enter next number, q to quit:\n");
    }
            
    return 0;
}

运行结果:

这种方法比较简单直接,但是有很大局限性。可以使用另外一种更加灵活的通用方法,将数字当作字符串来看待,通过反转赋值来实现判断。代码实现:

#include<stdio.h>
#include<string.h>
int main(void)
{
    char str[999];
    char str_reverse[999];
    int i,j;
    printf("plz enter:\n");
    gets(str);
    int n = strlen(str);
    printf("cotent is: %s\n", str);
    str_reverse[n] = '\0';
    
    for (i=0,j=n-1;i<n;i++,j--)
    {
        str_reverse[j] = str[i];
    }
    	
    printf("reverse content is: %s\n", str_reverse);

    if(strcmp(str_reverse, str) == 0)
        printf("%s is palindrome.\n", str);
    else
        printf("%s is not palindrome.\n", str);
    
    return 0;
}

运行结果:

三、判断水仙花数

水仙花数(Narcissistic number)也被称为超完全数字不变数(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),水仙花数是指一个 3 位数,它的每个数位上的数字的 3次幂之和等于它本身。例如:1^3 + 5^3+ 3^3 = 153。

水仙花数只是自幂数的一种,严格来说3位数的3次幂数才称为水仙花数。

其他位数的自幂数名字:

  • 一位自幂数:独身数
  • 三位自幂数:水仙花数
  • 四位自幂数:四叶玫瑰数
  • 五位自幂数:五角星数
  • 六位自幂数:六合数
  • 七位自幂数:北斗七星数
  • 八位自幂数:八仙数
  • 九位自幂数:九九重阳数
  • 十位自幂数:十全十美数

这个逻辑就非常简单了,只需要简单的判断加和即可。代码实现:

#include<stdio.h>
#include<math.h>

int main(void)
{
    int a,b,c;
    int num;

    for(num=100;num<1000;num++)
    {
        c = num%10;
        b = (num/10)%10;
        a = num/100;

        if(num == pow(a,3)+pow(b,3)+pow(c,3))
            printf("%0d is Armstrong number.\n",num);
    }

    return 0;
}

运行结果:

四、输出乘法表

依次输出乘法表,是一道比较基础的题,嵌套循环即可。参数可任意更改。

代码实现:

#include<stdio.h>
#define row 9
#define col 9
int main(void)
{
    int i,j;
    
    for(i=1;i<=row;i++)
    {
        for(j=1;j<=i;j++)
        {
            printf("%5d",i*j);
        }
        printf("\n");
    }

    return 0;
}

运行结果:

五、输出杨辉三角

杨辉三角是二项式系数在三角形中的一种几何排列,是中国古代数学的杰出研究成果之一。杨辉三角把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合。

杨辉三角的特性:

  1. 每个数等于它上方两数之和。
  2. 每行数字左右对称,由1开始逐渐变大。
  3. 第n行的数字有n项。
  4. 前n行共[(1+n)n]/2 个数。
  5. 第n行的m个数可表示为 C(n-1,m-1),即为从n-1个不同元素中取m-1个元素的组合数。
  6. 第n行的第m个数和第n-m+1个数相等 ,为组合数性质之一。
  7. 每个数字等于上一行的左右两个数字之和。可用此性质写出整个杨辉三角。即第n+1行的第i个数等于第n行的第i-1个数和第i个数之和,这也是组合数的性质之一。即 C(n+1,i)=C(n,i)+C(n,i-1)。
  8. (a+b)n的展开式中的各项系数依次对应杨辉三角的第(n+1)行中的每一项。
  9. 将第2n+1行第1个数,跟第2n+2行第3个数、第2n+3行第5个数……连成一线,这些数的和是第4n+1个斐波那契数;将第2n行第2个数(n>1),跟第2n-1行第4个数、第2n-2行第6个数……这些数之和是第4n-2个斐波那契数。
  10. 将第n行的数字分别乘以10^(m-1),其中m为该数所在的列,再将各项相加的和为11^(n-1)。例如有,11^0=1,11^1=1x10^0+1×10^1=11,11^2=1×10^0+2x10^1+1x10^2=121,11^3=1x10^0+3×10^1+3x10^2+1x10^3=1331,11^4=1x10^0+4x10^1+6x10^2+4x10^3+1x10^4=14641,11^5=1x10^0+5x10^1+10x10^2+10x10^3+5x10^4+1×10^5=161051。
  11. 第n行数字的和为2^(n-1)。1=2^(1-1),1+1=2^(2-1),1+2+1=2^(3-1),1+3+3+1=2^(4-1),1+4+6+4+1=2^(5-1),1+5+10+10+5+1=2^(6-1)。
  12. 斜线上数字的和等于其向左(从左上方到右下方的斜线)或向右拐弯(从右上方到左下方的斜线),拐角上的数字。1+1=2,1+1+1=3,1+1+1+1=4,1+2=3,1+2+3=6,1+2+3+4=10,1+3=4,1+3+6=10,1+4=5。
  13. 将各行数字左对齐,其右上到左下对角线数字的和等于斐波那契数列的数字。1,1,1+1=2,2+1=3,1+3+1=5,3+4+1=8,1+6+5+1=13,4+10+6+1=21,1+10+15+7+1=34,5+20+21+8+1=55。

对于实现过程,依旧需要使用嵌套循环,我们可以利用数组来进行操作,可以很方便地对每行的首尾赋值1。而每行的中间量是上一行值的和,最后控制打印空格和值。

代码实现:

#include<stdio.h>
int main(void)
{
    int row,col,level;
    printf("plz enter the level, press q to quit:\n");

    while(scanf("%d",&level) != 0)
    {
        int arr[level][level];

        for(row=0;row<level;row++)
        {
            arr[row][0] = 1;
            arr[row][row] = 1;
        }

        for(row=2;row<level;row++)
        {
            for(col=1;col<=row-1;col++)
            {
                arr[row][col] = arr[row-1][col-1] + arr[row-1][col];
            }
        }

        for(row=0;row<level;row++)
        {
            for(col=0;col<=level-row;col++)
            {
                printf("  ");
            }

            for(col=0;col<=row;col++)
            {
                printf("%5d",arr[row][col]);
            }
            printf("\n");
        }
        printf("\n");
        printf("plz enter next level, press q to quit:\n");
    }
    
    return 0;
}

根据传入的杨辉三角层级来创建二维数组。第一次循环,使得数组的头尾都为1。第二次循环,从这一行开始,数组值为上方的两数之和。第三次循环进行打印,根据排序依次打印空格和数字。

运行结果:

只要你的屏幕够大,还可以打印出更高层级的杨辉三角😀


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1178284.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构与算法C语言版学习笔记(2)-线性表、顺序存储结构的线性表

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 数据结构部分的知识框架一、线性表的定义和特点1.定义2.特点 二、线性表的实际案例引入1.案例一&#xff1a;多项式的加减乘除2.案例二&#xff1a;当多项式是稀疏多…

AI 女友突然下线,大叔集体「崩溃」;谷歌聊天机器人称谷歌滥用垄断力量丨 RTE 开发者日报 Vol.78

开发者朋友们大家好&#xff1a; 这里是 「RTE 开发者日报」 &#xff0c;每天和大家一起看新闻、聊八卦。我们的社区编辑团队会整理分享 RTE &#xff08;Real Time Engagement&#xff09; 领域内「有话题的 新闻 」、「有态度的 观点 」、「有意思的 数据 」、「有思考的 文…

微服务项目,请求从发出到后端处理器的历程

点击登录按钮,发出 http://localhost:8803/service_6001/admin/login/in请求,这是一个由nginx配置的前端项目 查看配置文件,该条请求会被映射形成对http://localhost:51603/admin/login/in的post请求 upstream heima-admin-gateway {server localhost:51603; } server {liste…

笔记50:正则表达式入门宝典

引自&#xff1a;正则表达式是什么? - 知乎 中“龙吟九野”所写的一个回答&#xff0c;个人感觉看完之后如同醍醐灌顶&#xff0c;查了很多资料都没有这篇文章写的基础和通透&#xff0c;感觉是正则表达式扫盲好文&#xff0c;所以搬运一下&#xff0c;侵权删&#xff0c;感谢…

吃透BGP,永远绕不开这些基础概述,看完再也不怕BGP了!

你们好&#xff0c;我的网工朋友。 总有人在私信里抱怨&#xff0c;BGP实在是太难了&#xff01; 一是这玩意儿本来就很复杂&#xff0c;需要处理大量的路由信息和复杂的算法&#xff1b;再一个是需要你有一定的实战经验才能深入理解运作。 虽然BGP确实有一定难度&#xff0c…

简简单单入门Makefile

笔记来源&#xff1a;于仕琪教授&#xff1a;Makefile 20分钟入门&#xff0c;简简单单&#xff0c;展示如何使用Makefile管理和编译C代码 操作环境 MacosVscode 前提准备 新建文件夹 mkdir learn_makefile新建三个cpp文件和一个头文件 // mian.cpp #include <iostrea…

fio数据整理之二

fio数据简单抓取 上文我们完成了一些fio output数据的简单抓取&#xff0c;本文将针对抓取的数据做进一步的处理&#xff0c;输出到表格之中&#xff0c;方便我们查看&#xff0c;统计结果。 本文先使用最简单的方法创建csv档案 我们现有个基本认知&#xff0c;在csv档案中&am…

通过you-get命令行工具下载B站等常见网站高清视频

参考&#xff1a; you-get&#xff1a;https://github.com/soimort/you-get EditThisCookie 源码&#xff1a;https://github.com/ETCExtensions/Edit-This-Cookie EditThisCookie 官网&#xff1a;https://www.editthiscookie.com/ you-get 是一个非常好用的命令行版视频下载工…

[wp]NewStarCTF 2023 WEEK5|WEB

前言:比赛是结束了&#xff0c;但我的学习还未结束&#xff0c;看看自己能复习几道题吧&#xff0c;第四周实在太难 Final 考点&#xff1a; ThinkPHP 5.0.23 RCE一句话木马上传SUID提权&#xff08;find&#xff09; 解题: 首先页面就给了ThinkPHP V5&#xff0c; 那无非考…

java制作游戏,如何使用libgdx,入门级别教学

第一步&#xff0c;进入libgdx的官网。点击get started 进入这个页面&#xff0c;点击setup a project 进入这个页面直接点击&#xff0c;Generate a project. 点击下载&#xff0c;下载创建工具 它会让你下载一个jar包&#xff0c;有java环境的人可以双击直接打开。 把android…

Linux学习之vim跳转到特定行数

参考的博客&#xff1a;《Vim跳到最后一行的方法》 《oeasy教您玩转vim - 14 - # 行头行尾》 《Linux&#xff1a;vim 中跳到首行和最后一行》 想要跳到特定行的话&#xff0c;可以在命令模式和正常模式进行跳转。要是对于vim的四种模式不太熟的话&#xff0c;可以到博客《Linu…

Arrays.asList() 和 List.of() 的列表之争

1. 概述 有时在Java中&#xff0c;为了方便&#xff0c;我们需要创建一个小列表或将数组转换为列表。Java 为此提供了一些辅助方法。 在本文中&#xff0c;我们将比较初始化小型临时数组的两种主要方法&#xff1a;List.of()和 Array.asList()。 2. Arrays.asList() Java 自…

跨境电商商城源码,助力商家全球布局(多语言切换\多货币转换\多商户入驻)

今天&#xff0c;我们要给大家介绍一款强大且多元化的跨境电商解决方案——WoShop跨境电商源码!这款源码拥有许多令人惊叹的功能&#xff0c;其中最引人注目的就是支持多语言切换、多货币转换以及多商户入驻! 设想一下&#xff0c;你是一个跨境电商的卖家&#xff0c;你的业务遍…

Cannot read properties of undefined (reading ‘prototype‘)

用vue注册的用import ElementUI from "element-ui"是不行的要用 import ElementUI from “element-plus”

【JAVA学习笔记】63 -坦克大战1.3-敌方发射子弹,击中坦克消失并爆炸,敌人坦克随机移动,规定范围限制移动

项目代码 https://github.com/yinhai1114/Java_Learning_Code/tree/main/IDEA_Chapter18/src/com/yinhai/tankgame1_3 〇、要求 增加功能 1.让敌人的坦克也能够发射子弹(可以有多颗子弹) 2.当我方坦克击中敌人坦克时&#xff0c;敌人的坦克就消失,如果能做出爆炸效果更好. …

Thread类的基本操作(JAVA多线程)

线程是操作系统中的概念&#xff0c;操作系统内核实现了线程这样的机制&#xff0c;并提供了一些API供外部使用。 JAVA中 Thread类 将系统提供的API又近一步进行了抽象和封装&#xff0c;所以如果想要使用多线程就离不开 Thread 这个类。 线程的创建(Thread类) 在JAVA中 创建…

SPSS多元方差分析

前言&#xff1a; 本专栏参考教材为《SPSS22.0从入门到精通》&#xff0c;由于软件版本原因&#xff0c;部分内容有所改变&#xff0c;为适应软件版本的变化&#xff0c;特此创作此专栏便于大家学习。本专栏使用软件为&#xff1a;SPSS25.0 本专栏所有的数据文件请点击此链接下…

大容量中间继电器 RXMH2 RK223 067 DC110V JOSEF约瑟

系列型号 RXMH2 RK 223 067大容量中间继电器&#xff1b; RXMH2 RK 223 068大容量中间继电器&#xff1b; RXMH2 RK 223 069大容量中间继电器&#xff1b; RXMH2 RK 223 070大容量中间继电器&#xff1b; 一、用途 RXMH2系列大容量中间继电器用于工业自动化控制及电力系统…

Git介绍及使用

目录 一、Git 的基本概念 1. 仓库&#xff08;Repository&#xff09;: 仓库是存储代码的地方。可以通过 命令将本地文件夹初始化为 Git 仓库&#xff0c;并使用 命令从远程仓库克隆到本地 2. 分支&#xff08;Branch&#xff09;: 分支是指从主分支上创建出来的一个分支&…

Python画一个爱心

Python画一个爱心 一、效果图二、Python代码 一、效果图 二、Python代码 import random from math import sin, cos, pi, log from tkinter import *CANVAS_WIDTH 640 # 画布的宽 CANVAS_HEIGHT 480 # 画布的高 CANVAS_CENTER_X CANVAS_WIDTH / 2 # 画布中心的X轴坐标 CA…