首页 > 其他分享 >【cs50 2022】lab1 && problem set1

【cs50 2022】lab1 && problem set1

时间:2023-06-26 18:44:19浏览次数:47  
标签:cs50 int number height cents lab1 2022 include calculate

|lab1|

#include <cs50.h>
#include <stdio.h>

int main(void)
{
    // TODO: Prompt for start size
    int start_size;
    do{
        start_size = get_int("Start size: ");
    }
    while(start_size<9);
    // TODO: Prompt for end size
    int end_size;
    do{
        end_size = get_int("End size: ");
    }while(end_size < start_size);
    // TODO: Calculate number of years until we reach threshold
    int year = 0;
    int born = 0;
    int pass = 0;
    while(start_size < end_size){
        born = start_size / 3;
        pass = start_size / 4;
        start_size = start_size + born - pass;
        year++;
    }
    // TODO: Print number of years
    printf("Years:  %i\n",year);
}

 

|problem set1|

 

 

 

 

#include <cs50.h>
#include <stdio.h>

int main(void)
{
    int height = 0;
    do{
        height = get_int("Height: ");
    }while(height < 1 || height > 8);
    int n = 1;
    for(int i = 0;i < height;i++){
        for(int j = 0;j<height-n;j++){
            printf(" ");
        }
        for(int m=0;m<n;m++){
            printf("#");
        }
        n++;
        printf("\n");
    }
}

 

#include <cs50.h>
#include <stdio.h>

int main(void)
{
     int height = 0;
    do{
        height = get_int("Height: ");
    }while(height < 1 || height > 8);
    int n = 0;
    for(int i=0;i<height;i++){
        for(int j=0;j<height-n;j++){
            printf(" ");
        }
        for(int m=0;m<n;m++){
            printf("#");
        }
        printf("  ");
        for(int k=0;k<n;k++){
            printf("#");
        }
        n++;
        printf("\n");
    }

}

cash

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

int get_cents(void);
int calculate_quarters(int cents);
int calculate_dimes(int cents);
int calculate_nickels(int cents);
int calculate_pennies(int cents);

int main(void)
{
    // Ask how many cents the customer is owed
    int cents = get_cents();

    // Calculate the number of quarters to give the customer
    int quarters = calculate_quarters(cents);
    cents = cents - quarters * 25;

    // Calculate the number of dimes to give the customer
    int dimes = calculate_dimes(cents);
    cents = cents - dimes * 10;

    // Calculate the number of nickels to give the customer
    int nickels = calculate_nickels(cents);
    cents = cents - nickels * 5;

    // Calculate the number of pennies to give the customer
    int pennies = calculate_pennies(cents);
    cents = cents - pennies * 1;

    // Sum coins
    int coins = quarters + dimes + nickels + pennies;

    // Print total number of coins to give the customer
    printf("%i\n", coins);
}

int get_cents(void)
{
    int cents = 0;
    do{
        cents = get_int("Change owed: ");
    }while(cents < 0);
    // TODO
    return cents;
}

int calculate_quarters(int cents)
{
    // TODO
    return  cents / 25;
}

int calculate_dimes(int cents)
{
    // TODO
    return cents / 10;
}

int calculate_nickels(int cents)
{
    // TODO
    return cents / 5;
}

int calculate_pennies(int cents)
{
    // TODO
    return cents;
}

credit

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


void show_result(long number);

int main(void)
{
    long number = 0;
    do{
        number = get_long("Number: ");
    }while(number<0);
    show_result(number);
}


void show_result(long number){
    int len = 0;
    long count_number = number;
    while(count_number>0){
       len++;
       count_number /=10;
    }
   //printf("lenth:%i\n",len);
   int card[20];
    long sum_number = number;
   // printf("show card\n");
    for(int i=len-1;i>0;i--){
        card[i] = sum_number %10;
        sum_number /= 10;
    }
    card[0] = sum_number;
   /*for(int i=0;i<len;i++){
        printf("%i",card[i]);
    }*/
   // printf("\n");
    int sum = 0;
    for(int i=0;i<len;i+=2){
        card[i]*=2;
        if(card[i]>9){
            sum += card[i] % 10;
            sum += card[i] / 10;
        }
        else{
            sum += card[i];
        }
    }
    for(int i=1;i<len;i+=2){
        sum += card[i];
    }
    if(sum % 10 == 0){
        printf("VISA\n");
    }else{
        printf("INVALID\n");
    }
}

 

标签:cs50,int,number,height,cents,lab1,2022,include,calculate
From: https://www.cnblogs.com/zhimingyiji/p/17506489.html

相关文章

  • [SWPUCTF 2022 新生赛]file_master wp
    前置知识点:这个题目的有一点之前是没有看见过的,就是对图片的宽和高进行了一些限制,限制都小于20才能上传成功看了别人的wp说是可以直接定义#defineheight1#definewidth1就是上面的只要把后面的数字改成小于20的就可以了(20是题目要求的,imagehightandwidthmustl......
  • 关于VS2022---Git使用指南
    第一步 输入对应的地址,并点击创建并推送第二步:添加文件、修改文件、删除文件  点击添加修改项,并推送数据库......
  • 发布一个Visual Studio 2022 插件,可以自动完成构造函数依赖注入代码
    赖注入(DI)在开发中既是常见的也是必需的技术。它帮助我们优化了代码结构,使得应用更加灵活、易于扩展,同时也降低了各个模块之间的耦合度,更容易进行单元测试,提高了编码效率和质量。不过,手动注入依赖项也可能会成为我们开发过程中的瓶颈。通常情况下,当我们需要注入大量依赖对象时,我......
  • 【专题】2022年中国跨境电商行业研究报告PDF合集分享(附原数据表)
    全文链接:http://tecdat.cn/?p=32044近年来,我国的跨境电子商务发展迅速,在过去五年中,其贸易额增长率达到了16.2%,已经成为稳定对外贸易的一支重要力量一方面,随着跨境电子商务的发展,跨境电子商务的监管政策得到了进一步的改善,跨境电子商务的规模也得到了进一步的扩大,整个电子商务的......
  • SEERC2022(E,F,H,K)
    正题比赛链接:https://codeforces.com/gym/104114E-Exercise【dp,贪心】题目大意给出长度为\(2n\)的序列\(c_{i}\),将\(1\sim2n\)两两配对使得每一对\((a_i,b_i)\)的\(|c_{b_i}-c_{a_i}|\)总和最小且对于任意\(i\)不存在\(2i-1\)与\(2i\)配对的情况。\(1\leq......
  • 百度网盘下载慢怎么解决2022(4种免费提速方法)
    摘自:http://baike.jld5.cn/news/49696.html工信部终于针对网盘免费用户下载速度慢的问题出手了,要求各网盘企业在同样的网络条件下,对免费用户提供的上传和下载的最低速率应确保满足基本的下载需求,并且要求此项任务于2021年12月底前完成。看到这则消息时,给小编的第一感觉是网盘免......
  • 安装新版VS2022之后,添加EF实体模型没有生成对于的表格
    1)找到vs2022安装路径中的EF6.Utility.CS.ttinclude.tt文件,需要去掉.tt后缀,然后再做以下修改【部分版本直接是EF6.Utility.CS.ttinclude则直接进入第二步】2)修改EF6的实用程序EF6.Utility.CS.ttinclude文件,它默认的位置在:C:\ProgramFiles\MicrosoftVisualStudio\2022\Profes......
  • 洛谷P8341 [AHOI2022] 回忆
    [AHOI2022]回忆题目背景生活在题面里的他们,是一群怪异的少年。对城市中修建道路需满足的基本物理限制熟视无睹,沉迷于十万个城市、百万条道路上的各种结构。明明知道真正需要的数字庞大到无法计算,却偏要关心它模一个奇怪素数之后得到的结果。如此智力超群的他们,却总是在自己......
  • 2022年最新对比学习(Contrastive Learning)相关必读论文整理分享
        要说到对比学习(ContrastiveLearning),首先要从自监督学习开始讲起。自监督学习属于无监督学习范式的一种,特点是不需要人工标注的类别标签信息,直接利用数据本身作为监督信息,来学习样本数据的特征表达,并用于下游任务。    当前自监督学习可以被大致分为两类:    Genera......
  • 多伦多大学-强化学习导论-2022
    课程描述    这是一门关于不确定条件下强化学习和顺序决策的入门课程,重点在于理解理论基础。我们研究如何使用价值和策略迭代等动态规划方法来解决具有已知模型的顺序决策问题,以及如何扩展这些方法来解决模型未知的强化学习问题。其他主题包括,RL中的函数逼近、策略梯度方法......