C语言 第六章 多重循环练习-阿里云开发者社区

开发者社区> 张果> 正文

C语言 第六章 多重循环练习

简介: 一、循环输入 #include "stdio.h" void main() { char c; do { printf("我告诉你1+1=2\n"); printf("你相信吗?(y/n)"); c=get...
+关注继续查看

一、循环输入

#include "stdio.h"
void main()
{
    char c;
    do
    {
        printf("我告诉你1+1=2\n");
        printf("你相信吗?(y/n)");
        c=getchar();
        fflush(stdin);
    }while(c=='n');
}

二、输入行与列显示矩形

#include "stdio.h"
void main()
{
   int row,col,i,j;
   char c;
   
   do{
       printf("行:");
       scanf("%d",&row);
       fflush(stdin);
       
       printf("列:");
       scanf("%d",&col);
       fflush(stdin);
       
       for(i=1;i<=row;i++)
       {
               for(j=1;j<=col;j++)
               {
                   printf("*");
               }
               printf("\n");
       }
        printf("是否继续?(y/n)");
        c=getchar();
        fflush(stdin);
   }while(c=='y');
    
}

三、1-10之间的阶乘

1!+2!+3!

1+(1*2)+(1*2*3)

#include "stdio.h"
void main()
{
    int i,j,n,cnt,sum=0;
   
    for(j=1;j<=10;j++)
    {
        cnt=1;
        for(i=1;i<=j;i++)
        {
            cnt=cnt*i;
            printf("%d x ",i);
        }
        sum+=cnt;
        printf("=%d\n",cnt);
    }
    printf("%d",sum);
}

四、买苹果

#include "stdio.h"
void main()
{
    //总苹果数x0.8/天数=每天花的钱
    int n,cnt=0,day=0; //表示当天买的苹果数
    for(n=2;n<=100;n=n*2,day++)
    {
        cnt=cnt+n;  //累加每天的苹果数
        printf("%d %d\n",n,cnt);
    }
    
    printf("%.2f",(cnt*0.8)/day);
}

五、课后练习吃饭吃菜

#include "stdio.h"
void main()
{
    int i,j;
    for(i=1;i<=10;i++)
    {
        printf("\n吃一口饭\n");
        for(j=1;j<=3;j++)
        {
            printf("吃菜\t");
        }
    }
}

六、分解质因数

/* Note:Your choice is C IDE */
#include "stdio.h"
void main()
{
    int i,n;
    scanf("%d",&n);  //输入
    for(i=2;i<=n;i++)  //假定i-n之间的所有数都是n的质因数
    {
        if(n%i==0)  //是否整除
        {
            printf("%d \t",i);
            n=n/i;
            i--;  //为了避免跳过多个相同因子将i--
        }
        //n=28 14 7 1
        //i=2 1 2 1 2 3 4  5 6 7 6 7 8
    }
    //2 2 7
}

七、101-200间的素数,P136

/* Note:Your choice is C IDE */
#include "stdio.h"
void main()
{
    //判断一个数是否是素数
    int n=101,leap,i,cnt=0;
    
    while(n<=200)  //外重循环用于准备数
    {
        leap=1;  //假定n就是素数
        for(i=2;i<n/2;i++)
        {
            if(n%i==0)  //只要在2-n之间有一个数被整除
            {
                leap=0;  //标记n不是素数
                break;  //结束内重循环
            }
        }
        
        if(leap)
        {
            cnt++;
            printf("%d  ",n);
            if(cnt%10==0) printf("\n");   //当素数个数是10的倍数时换行 
        }
        n++;
    }
    
    printf("\n101-200之间共有%d个素数",cnt);
    
    
}

八、乒乓球比赛题 P140

#include "stdio.h"
void main()
{
    int i,j;
    for(i='a';i<='c';i++)
    {
        for(j='x';j<='z';j++)
        {
            if(i=='a'&&j=='x'||(i=='c'&&(j=='x'||j=='z'))) continue;
            printf("%c VS %c \n",i,j);
        }
    }
}

#include "stdio.h"
void main()
{
    int i,j,k=0,flag=0,n=0;
    char a[]="abc";
    char b[]="xyz";
    char c[3];
    
    for(i=2;i>=0;i--)
    {
        for(j=0;j<=2;j++)
        {
            if(a[i]=='a'&&b[j]=='x'||(a[i]=='c'&&(b[j]=='x'||b[j]=='z'))) continue;
            
            //如果数组中已存在则不行
            flag=0;
            for(k=0;k<3;k++)
            {
                if(c[k]==b[j]){flag=1;break;};
            }
            
            //存入数组中
            if(flag==0){
               c[n++]=b[j];
               break;
            }
        }
    }
    
    for(i=0;i<3;i++)
    {
        printf("%c对%c \t",a[i],c[2-i]);
    }
}

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Vue 仿钉钉流程图(流程节点绘制 vue+Ant【如果用其他UI库需要替换几个组件】 附 demo)
# [这里是git地址](https://gitee.com/xiaoyaoluntian/imitating-dingding-flow-chart/tree/comdemo/)
6 0
计算机基础3 | 学习笔记
快速学习计算机基础3。
10 0
【在家实践】 ECS 初体验
第一次体验云服务器,感觉十分奇妙。
16 0
解决echarts地图geoJson报错问题(“echarts.min.js:45 Uncaught Error: Invalid geoJson format Cannot read prope”)
解决报错: 1.Invalid geoJson format Cannot read property ‘length’ of undefined 2 echarts.min.js:45 Uncaught Error: Invalid geoJson format Cannot read prope
6 0
数据类型-数值和字符串 | 学习笔记
快速学习数据类型-数值和字符串。
5 0
Linux 基本操作 | 学习笔记
快速学习 Linux 基本操作。
11 0
【技术干货】40页PPT分享万亿级交易量下的支付平台设计(2)
【技术干货】40页PPT分享万亿级交易量下的支付平台设计(2)
9 0
阿里云初体验
web开发打包部署到linux服务器
21 0
Java classloader详解
Java程序并不是一个可执行文件,而是由很多的Java类组成,其运行是由JVM来控制的。而JVM从内存中查找到类,而真正将类加载进内存的就是ClassLoader,可以说我们每天都在接触ClassLoader,但是很多时候我们没有明白其执行的流程和原理。
8 0
研发职位到底应该怎么设置?(下)
研发职位到底应该怎么设置?(下)
5 0
+关注
张果
毕业于湖南工业大学计算机科学与技术专业,是一位全栈开发工程师,拥有十多年软件开发经验,独立完成数十个商业项目。擅长前端、Java与DotNet平台下的软件设计与软件工程技术。
36
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载