C语言实验 循环结构

时间:2024.11.8

一、实验

7-1 求交错序列前N项和

#include<stdio.h>
#include<math.h>
int main(){
    int n;
    double a,b,c;
    double sum=0;
    scanf("%d",&n);
    for(int i=1;i<=n;i++){
        a=pow(-1,i+1)*i;
        b=2.0*i-1.0;
        c=1.0*a/b;
        sum+=c;
    }

    printf("%.3lf",sum);
    return 0;
}

TIPS:

++注意变量的类型,整型的计算无法满足小数的要求++

++7-2 寻找250++

#include<stdio.h>
#include<math.h>
int main(){
    int n;
   
    for(int i=1; ;i++){
      
    if(n==250){
     printf("%d",i-1);
        break;
    }
   scanf("%d",&n);
    } 
    return 0;
}

TIPS:

++注意循环的退出和输入数据的时机 。++

++7-3 最大公约数和最小公倍数++

#include<stdio.h>
#include<math.h>
int main(){
    int m,n,t,p;
   scanf("%d %d",&m,&n);
    t=m>n?n:m;
    
  while(1){    
    if(m%t==0&&n%t==0){
  
        break;
    }else t--;}
  p=m*n/t;
  printf("%d %d",t,p);
    return 0;
}

TIPS:

++最大公约数和最小公倍数的找法,如果两个都需要求,可以通过简便方法由最大公因数求最小公倍数。++

7-4 统计字符

#include<stdio.h>
#include<math.h>
int main(){
    char m;
   int l=0,b=0,d=0,o=0;
    
  for(int i=1;i<=10;i++){ 
      scanf("%c",&m);
    if((m>='a'&&m<='z')||(m>='A'&&m<='Z')){
     l++;
        
    }else if(m==' '||m=='\n'){
       b++; 
       
    }else if(m<='9'&&m>='0'){
       d++;
     
    }else {o++;}

      }
 
  printf("letter = %d, blank = %d, digit = %d, other = %d",l,b,d,o);
    return 0;
}

7-5 大笨钟

#include<stdio.h>
#include<math.h>
int main(){
    int m,h,n;
   scanf("%d:%d",&h,&m);
   
       if((h<12)||(h==12&&m==0)){
       printf("Only %02d:%02d.  Too early to Dang.",h,m);
   }else {
       if(m==0){
          
           n=h-12;
       }else n=h-11;
for(int i=1;i<=n;i++)
{printf("Dang");}}
    return 0;
}

TIPS:

++先考虑一般情况,再考虑整点,分界点(零点、中午12点) 等的特殊情况++

7-6 统计选票

#include<stdio.h>
#include<math.h>
int main(){
    int t=0,j=0,n,s=0,f=0;
do{
    scanf("%d ",&n);
   if(n==1) t++;
 else if(n==1) t++;
 else if(n==2) j++;
 else if(n==3) s++;
    else if(n==0||n==4) f++;
}while(n!=-1);
  
   printf("Tom = %d Jerry = %d Spike = %d Invalid = %d\n",t,j,s,f);
   if(t<=f&&j<=f&&s<=f)
   {  printf("Election invalid!");}
    return 0;
}

TIPS:

++注意输出的顺序,哪个语句在前,哪个语句在后,注意输出和输入是否需要换行++

7-7 降价提醒机器人

#include<stdio.h>
#include<math.h>
int main(){
    int m,n;
    double h;
   scanf("%d %d\n",&n,&m);
   for(int i=1;i<=n;i++){
       scanf("%lf\n",&h);
       if(h<(m*1.0)){
           printf("On Sale! %.1lf\n",h);
       }
   }
    
    return 0;
}

7-8 幸运彩票

#include<stdio.h>
#include<math.h>
int main(){
    int m,n;
    int q,h;
   scanf("%d\n",&n);
   for(int i=1;i<=n;i++){
       scanf("%d\n",&m);
       q=m/100000+m/10000%10+m/1000%10;
       h=m%10+m%100/10+m%1000/100;
       if(q==h){
           printf("You are lucky!\n");
       }else 
           printf("Wish you good luck.\n"); 
   }
    
    return 0;
}

二、知识点

2.1注意变量的类型,整型的计算无法满足小数的要求

2.2注意循环的退出和输入数据的时机 (break的使用)

2.3最大公约数和最小公倍数的找法。

相关推荐
九年义务漏网鲨鱼几秒前
【人脸伪造检测后门攻击】 Exploring Frequency Adversarial Attacks for Face Forgery Detection
论文阅读·python·算法·aigc
一个数据小开发1 分钟前
业务开发问题之ConcurrentHashMap
java·开发语言·高并发·map
_OLi_6 分钟前
力扣 LeetCode 977. 有序数组的平方(Day1:数组)
数据结构·算法·leetcode
励志成为嵌入式工程师21 分钟前
c语言选择排序
c语言·算法·排序算法
三小尛23 分钟前
希尔排序(C语言)
c语言·数据结构·排序算法
風清掦25 分钟前
C/C++每日一练:编写一个查找子串的位置函数
c语言·c++·算法
三小尛28 分钟前
插入排序(C语言)
c语言·开发语言
南宫理的日知录33 分钟前
106、Python并发编程:深入浅出理解线程池的内部实现原理
开发语言·python·学习·编程学习
WolvenSec38 分钟前
C/C++逆向:结构体逆向分析
c语言·开发语言·c++·网络安全
A charmer43 分钟前
算法每日双题精讲——滑动窗口(最大连续1的个数 III,将 x 减到 0 的最小操作数)
c++·算法·leetcode