2023-12-16 课后练习(复习+结构体练习)

2023-12-16 17:04

本文主要是介绍2023-12-16 课后练习(复习+结构体练习),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:分式运算,1-1/2+1/3-1/4+…+1/99-1/100

代码:

#include<stdio.h>
int main()
{int i = 1;//项数,初始值为1double deno = 2;//分母,初始值为2,从第二项开始double n = 1;//项的数值,初始值为1double sum=1;//和的初始值为1while (deno <= 100){i++;if (i % 2 == 0)//如果为偶数项则改变正负号{deno = -deno;}n = 1 / deno;sum += n;deno++;}printf("%.9lf", sum);return 0;
}

另一种方法:

#include<stdio.h>
int main()
{int i = 1;//项数,初始值为1double deno = 2;//分母,初始值为2,从第二项开始double n = 1;//项的数值,初始值为1double sum = 1;//和的初始值为1while (deno <= 100){i++;n = 1 / deno;if (i % 2 == 0)//如果为偶数项则改变正负号{n = -n;}sum += n;deno++;}printf("%.9lf", sum);return 0;
}

运行结果:

0.688172179

题目:投票结果

代码:

#include<string.h>
struct Student
{char name[20];//候选人姓名int count;//候选人得票数
}
leader[3]={"Messi",0,"Mbappe",0,"Haaland",0};//定义结构体数组初始化int main()
{int i, j;char leader_name[20];for (i = 1; i <= 4; i++){scanf("%s", leader_name);for (j = 0; j < 3; j++){if (strcmp(leader_name, leader[j].name) == 0)leader[j].count++;}}printf("\nResult:\n");for (i = 0; i < 3; i++){printf("%5s:%d\n", leader[i].name, leader[i].count);}return 0;
}

运行结果:

Messi
Mbappe
Haaland
MessiResult:
Messi:2
Mbappe:1
Haaland:1

 题目:指向结构体变量的指针

代码:

#include<stdio.h>
#include<string.h>
struct date
{int year, month, day;
};struct student
{int num;char name[20];char sex;struct date bday;double score;
};
int main()
{struct student s;struct student* p = &s;s.num = 10;strcpy(s.name, "Messi");s.score = 99.9;printf("%d,%s,%lf\n", p->num, p->name, p->score);return 0;
}

运行结果:

10,Messi,99.900000

这篇关于2023-12-16 课后练习(复习+结构体练习)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/501219

相关文章

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

结构体和联合体的区别及说明

《结构体和联合体的区别及说明》文章主要介绍了C语言中的结构体和联合体,结构体是一种自定义的复合数据类型,可以包含多个成员,每个成员可以是不同的数据类型,联合体是一种特殊的数据结构,可以在内存中共享同一... 目录结构体和联合体的区别1. 结构体(Struct)2. 联合体(Union)3. 联合体与结构体的

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

RabbitMQ练习(AMQP 0-9-1 Overview)

1、What is AMQP 0-9-1 AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。 AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

【Rust练习】12.枚举

练习题来自:https://practice-zh.course.rs/compound-types/enum.html 1 // 修复错误enum Number {Zero,One,Two,}enum Number1 {Zero = 0,One,Two,}// C语言风格的枚举定义enum Number2 {Zero = 0.0,One = 1.0,Two = 2.0,}fn m

MySql 事务练习

事务(transaction) -- 事务 transaction-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求-- 事务的操作要么同时成功,要么同时失败-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账-- 逻辑:A给B转账1000:1.查询

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param