jjzjj

C语言循环结构一些重要的练习题(较为基础的)

最爱麻辣烫面 2024-07-10 原文
循环结构
1.求累加和问题
void main()
{
    int i = 0;
    int sum = 0;
    while (i <= 100) {//求1到100累加和
        sum = sum + i;
        i++;
    }printf("%d\n", sum);
}
void main() {
    int i = 0;
    int sum = 0;
    while (i <= 100) {//求1到100偶数累加和
        printf("%d\n", i);
        sum = sum + i;
        i += 2;
    }printf("%d\n", sum);
}
void main() {
    int i = 1;
    int sum = 0;
    while (i <= 100) {//求1到100奇数累加和
        printf("%d\n", i);
        sum = sum + i;
        i += 2;
    }printf("%d\n", sum);
}
void main()
{
       int i = 1;
       int sum = 0;
       int sign = 1;
       while (i <= 100) {//1-2+3-4+......-100
               printf("%u\n", i);
               sum = sum + sign * i;
               i++;
               sign = -sign;
       }printf("%d\n", sum);
}
void  main() {
       int i = 1;
       float sum = 0;
       while (i <= 100) {//1+1/2+1/3+....+1/100
               sum = sum + 1.0/i;
               i++;
       }printf("sum=%f\n", sum);
}

2.输出字母A-Z
void main() {
       char i = 'A';
       while (i <= 'Z') {
               printf("%c\n", i);
               i++;   
       }
}

3.输入正整数n,计算并输出n!
void main() {
       int n, f, i;
       printf("请输入n:");
       scanf_s("%d", &n);
       for (i = 1, f = 1; i <= n; i++)
               f = f * i;
       printf("%d!=%d\n", n, f);
}

4.将一个正整数倒序输出
void main(){
       int x,d;
       scanf_s("%d", &x);
       printf("%d的倒序是:", x);
       while (x != 0) {
               d = x % 10;
               x = x / 10;
               printf("%d",d);
       }
}

5.打印九九乘法表
void main() {
    int i, j;
    for (i = 1; i <= 9; i++) {
        for (j = 1; j <= i; j++) {
            printf("%d*%d=%-4d", i, j, i * j);
        }printf("\n");
    }
}

6.输出三角形、菱形
void main() {
       int i, j;
       for (i = 1; i <= 4; i++) {
               for (j = 1; j <= i; j++) {
                      printf("*");
               }printf("\n");
       }
}
void main() {
       int i, j;
       for (i = 1; i <= 4; i++) {
               for (j = 1; j <= 5 - i; j++) {
                      printf("*");
               }printf("\n");
       }
}
void main() {
       int i, j;
       for (i = 1; i <= 4; i++) {
               for (j = 1; j <= 2 * i - 1; j++) {
                      printf("*");
               }printf("\n");
       }
}
void main() {
       int i, j;
       for (i = 1; i <= 4; i++) {
               for (j = 1; j <= 5- i; j++) {
                      printf(" ");
               }
               for (j = 1; j <= 2 * i - 1; j++) {
                      printf("*");
               }printf("\n");
       }
}
void main() {
       int i, j;
       for (i = 1; i <= 4; i++) {
               for (j = 1; j <= 4 - i; j++) {
                      printf(" ");
               }
               for (j = 1; j <= 2 * i - 1; j++) {
                      printf("*");
               }printf("\n");
               }
       for(i=3;i>=1;i--){
               for (j = 1; j <= 4 - i; j++) {
                      printf(" ");
               }
               for (j = 1; j <= 2 * i - 1; j++) {
                      printf("*");
               }printf("\n");
       }
}

7.continue语句和break语句
void main() {
       int i = 0;
       int sum = 0;
       while (2) {
               if (i > 100)break;
               sum = sum + i;
               i++;
       }printf("%d", sum);
}

void main() {
       char c;
       while (1) {
               c = getchar();
               if (c >= 'a' && c <= 'z')
                      putchar(c - 32);
               else
                      break;
       }
}
void main() {
    char c;
    scanf_s("%c", &c);
    while (1) {
        if (c >= 'a' && c <= 'z') {
            c = c - 32;
            putchar(c);
        }
        else
            break;
    }
}

8.输出100-200之间不能被3整除的数
void main() {
       int i;
       for (i = 100; i <= 200; i++) {
               if (i % 3 != 0)
                      printf("%4d", i);
       }
}
void main() {
       int i;
       for (i = 100; i <= 200; i++) {
               if (i % 3 == 0)
                      continue;
                      printf("%4d", i);
       }
}

9.求Pi的值,根据

void main() {
       int sign = 1;
       double pi = 0, n = 1, term = 1;
       while (fabs(term) >= 1e-6) {
               pi = pi + term;
               n = n + 2;
               sign = -sign;
               term = sign / n;
       }pi = pi * 4;
       printf("%10.8f", pi);
}

10.求斐波那契数列前k项的值
void main() {
       int f1 = 1;
       int f2 = 1;
       int i;
       int k;
       scanf_s("%d", &k);    
       for (i = 1; i <= k; i++) {
               printf("%12ld%12ld", f1, f2);
               if (i % 2 == 0)printf("\n");
               f1 = f1 + f2;
               f2 = f2 + f1;
       }
}
void main() {
    int i, n, k;
    scanf_s("%d", &k);
    long a, b, next;
    a = b = 1;
    printf("%20ld%20ld", a, b);
    n = 2;
    for (i = 3; i <= k; i++) {
        next = a + b;
        printf(" % 20ld", next);
        n++;
        if (n % 4 == 0)printf("\n");
        a = b;
        b = next;
    }
}

11.判断一个数是否为素数
void main() {
       int i;
       int n;
       scanf_s("%d", &n);
       for (i = 2; i <= n - 1; i++)
               if (n % i == 0)break;
       if (i >= n)
               printf("%d是素数", n);
       else
               printf("%d不是素数",n);
}
#include <stdio.h>
#include<math.h>
#define _CRT_SECURE_NO_WARNINGS
void main() {
       int i;
       int n;
       scanf_s("%d", &n);
       int temp = (int)(sqrt(n));
       for (i = 2; i <=temp; i++)
               if (n % i == 0)break;
       if (i >= temp)
               printf("%d是素数", n);
       else
               printf("%d不是素数", n);
}

12.输出特定范围内的所有素数(3-99)
void main() {
       int i;
       int n;
       for (n = 3; n <=99; n++){
               for(i=4;i<=n-1;i++)
               if (n % i == 0)break;
               if (i >= n)
                      printf("%d是素数\n", n);
       }
}

13.在全系1000名学生中,,征集慈善募捐,当总数到达10万元时就停止,输出捐款人数,和捐款总钱数
void main() {
       int i = 0;
       float sum = 0;
       float x;
       for (i = 1; i <= 1000; i++) {
               scanf_s("%f", &x);
               sum = sum + x;
               if (sum >= M) {
                      break;
               }
       }
       if (i <= 1000) {
               printf("%d\n%f", i, sum);
       }
       else
               printf("%d\n%f", i - 1, sum);
}

14. 输入一行字符,分别统计出其中英文字母、空格、数字和其他字符的个数
void main() {
       int c1 = 0, c2 = 0, c3 = 0, c4 = 0;
       printf("请输入一行字符:");
       char c;
       while ((c = getchar()) != '\n') {
               if (c >= 'a' && c <= 'z'|| c >= 'A' && c <= 'Z')
                      c1++;
               else if (c >= '0' && c <= '9')
                      c2++;
               else if (c == ' ')
                      c3++;
               else
                      c4++;
       }printf("字母数:%d\n数字数:%d\n空格数:%d\n其他符号数:%d\n", c1, c2, c3, c4);
}

15.辗转相除法输出最大公约数
void main() {
    int r, m, n, t;
    scanf_s("%d\n%d", &m, &n);
    if (m < n) {
        t = m;
        m = n;
        n = t;
    }
    while (2) {
        r = m % n;
        if (r == 0) {
            printf("%d", n);
            break;
        }
        m = n;
        n = r;
    }
}

16.
void main() {
       int n, i;
       float fac, sum = 0;
       for (n = 1; n <= 20; n++) {
               i = 1; fac = 1;
               do {
                      fac = fac * i;
                      i++;
               } while (i <= n);
               sum = sum + fac;
       }printf("sum=%e\n", sum);
}
void main() {
       int n;
       float fac = 1, sum = 0;
       for (n = 1; n <= 20; n++) {
               fac = fac * n;
               sum = sum + fac;
       }printf("sum=%e\n", sum);
}

17.
void main() {
       int n;
       float fac = 1, sum = 0;
       for (n = 1; n <= 20; n++) {
               fac = fac * 2;
               sum = sum + fac;
       }printf("sum=%e\n", sum);
}

18.百钱百鸡问题
void main() {
       int x, y, z;
       for (x = 0; x <= 100; x++) {
               for (y = 0; y <= 100; y++) {
                      z = 100 - x - y;
                      if (15 * x + 9 * y + z==300) {
                              printf("公鸡:%8d\t母鸡:%8d\t小鸡:%8d\n", x, y, z);
                      }
               }
       }
}

19.100-1000的所有水仙花数
void main() {
       int i;
       int b0, b1, b2;
       for (i = 100; i <= 999; i++) {
               b0 = i % 10;
               b1 = i / 10 % 10;
               b2 = i / 100;
               if (b0 * b0 * b0 + b1 * b1 * b1 + b2 * b2 * b2 == i)
                      printf("水仙花数:%d\n", i);
       }
}

20.译密码
void main() {
       char c;
       c = getchar();
       while (c != '\n') {
               if (c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z') {
                      if (c >= 'w' && c <= 'z' || c >= 'W' && c <= 'Z') {
                              c = c - 22;
                      }else c = c + 4;
               }printf("%c", c);
       }
}

21.找出1000以内的所有完数
void main() {
       int i,k,s;
       for (i = 1; i < 1000; i++) {
               s = 0;
               for (k = 1; k < i; k++)       
                      if (i % k == 0)
                              s = s + k;
               if (s == i)
                      printf("%d\n", i);
       }
}
暂时就整理了这些,近两天还会整理数组什么的和之后的内容,都是很基础的,加油。

有关C语言循环结构一些重要的练习题(较为基础的)的更多相关文章

  1. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

  2. ruby - 树顶语法无限循环 - 2

    我脑子里浮现出一些关于一种新编程语言的想法,所以我想我会尝试实现它。一位friend建议我尝试使用Treetop(Rubygem)来创建一个解析器。Treetop的文档很少,我以前从未做过这种事情。我的解析器表现得好像有一个无限循环,但没有堆栈跟踪;事实证明很难追踪到。有人可以指出入门级解析/AST指南的方向吗?我真的需要一些列出规则、常见用法等的东西来使用像Treetop这样的工具。我的语法分析器在GitHub上,以防有人希望帮助我改进它。class{initialize=lambda(name){receiver.name=name}greet=lambda{IO.puts("He

  3. ruby-on-rails - 在 Ruby 中循环遍历多个数组 - 2

    我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代

  4. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  5. ruby - RuntimeError(自动加载常量 Apps 多线程时检测到循环依赖 - 2

    我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("

  6. ruby - 寻找通过阅读代码确定编程语言的ruby gem? - 2

    几个月前,我读了一篇关于ruby​​gem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:

  7. ruby - 是否有用于序列化和反序列化各种格式的对象层次结构的模式? - 2

    给定一个复杂的对象层次结构,幸运的是它不包含循环引用,我如何实现支持各种格式的序列化?我不是来讨论实际实现的。相反,我正在寻找可能会派上用场的设计模式提示。更准确地说:我正在使用Ruby,我想解析XML和JSON数据以构建复杂的对象层次结构。此外,应该可以将该层次结构序列化为JSON、XML和可能的HTML。我可以为此使用Builder模式吗?在任何提到的情况下,我都有某种结构化数据-无论是在内存中还是文本中-我想用它来构建其他东西。我认为将序列化逻辑与实际业务逻辑分开会很好,这样我以后就可以轻松支持多种XML格式。 最佳答案 我最

  8. ruby-on-rails - 如何生成传递一些自定义参数的 `link_to` URL? - 2

    我正在使用RubyonRails3.0.9,我想生成一个传递一些自定义参数的link_toURL。也就是说,有一个articles_path(www.my_web_site_name.com/articles)我想生成如下内容:link_to'Samplelinktitle',...#HereIshouldimplementthecode#=>'http://www.my_web_site_name.com/articles?param1=value1¶m2=value2&...我如何编写link_to语句“alàRubyonRailsWay”以实现该目的?如果我想通过传递一些

  9. Unity 热更新技术 | (三) Lua语言基本介绍及下载安装 - 2

    ?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------

  10. 7个大一C语言必学的程序 / C语言经典代码大全 - 2

    嗨~大家好,这里是可莉!今天给大家带来的是7个C语言的经典基础代码~那一起往下看下去把【程序一】打印100到200之间的素数#includeintmain(){ inti; for(i=100;i 【程序二】输出乘法口诀表#includeintmain(){inti;for(i=1;i 【程序三】判断1000年---2000年之间的闰年#includeintmain(){intyear;for(year=1000;year 【程序四】给定两个整形变量的值,将两个值的内容进行交换。这里提供两种方法来进行交换,第一种为创建临时变量来进行交换,第二种是不创建临时变量而直接进行交换。1.创建临时变量来

随机推荐