0614,表达式,语句

题目一:

许多简单的交互式程序都是基于菜单的:它们向用户显示可供选择的命令列表;一旦用户选择了某条命令,程序就执行相应的操作,然后提示用户输入下一条命令;这个过程一直会持续到用户选择 "退出" 或 "停止" 命令。

这类程序的核心显然是循环。循环内将有语句提示用户输入命令,读命令,然后确定执行的操作

for (; ;) {
    提示用户输入命令;
    读入命令;
    执行命令;
}

执行命令将用到 switch 语句 (或者级联式 if 语句):

for (; ;) {
    提示用户输入命令;
    读入命令;
    switch (命令) {
        case 命令1: 执行操作; break;
        case 命令2: 执行操作; break;
        ...
        case 命令n: 执行操作; break;
        default: 显示错误信息; break;
    }
}

现在请开发一个记账程序。程序将为用户提供选择菜单:清空账户余额,往账户上存钱,从账户上取钱,显示当前余额,退出程序。选择项分别用整数 0、1、2、3 和 4 表示。程序的会话类似这样:

*** checkbook-balancing program ***
Commands: 0=clear, 1=credit, 2=debit, 3=balance, 4=exit

Enter command: 1
Enter amount of credit: 1000.0
Enter command: 2
Enter amount of debit: 100.0
Enter command: 3
Current balance: $900.00
Enter command: 9
Commands: 0=clear, 1=credit, 2=debit, 3=balance, 4=exit

Enter command: 0
Enter command: 3
Current balance: $0.00
Enter command: 4
代码一/解答:

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>

int main(void) {
	int command=0; float credit = 0.0f; float add_or_del;
	printf("*** checkbook-balancing program ***\nCommands: 0 = clear, 1 = credit, 2 = debit, 3 = balance, 4 = exit\n\n");
	
	for (;command!=4;) {
		printf("Enter command: ");
		scanf("%d", &command);
		switch (command)
		{
		case 0: 
		{
			credit =0.0;
			break;
		}
		case 1:
		{
			printf("Enter amount of credit: ");
			scanf("%f", &add_or_del);
			credit += add_or_del;
			break;
		}
		case 2:
		{
			printf("Enter amount of debit: ");
			scanf("%f", &add_or_del);
			credit -= add_or_del;
			break;
		}
		case 3: 
		{
			printf("Current balance: $%.2f\n",credit);
			break;
		}
		default:
		{
			printf("Commands: 0 = clear, 1 = credit, 2 = debit, 3 = balance, 4 = exit\n\n");
			break;
		}
		case 4:break;
		}
	}

	return 0;
}
答案:

 

发现一个蛮好玩的事情,1.2的时候,不知道怎么回事

exit(0);是老师退出循环的语句,for循环里面就没有放任何表达式

其他就是,我的长的丑哭死

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>


int main(void) {
	printf("*** checkbook-balancing program ***\n");
	printf("Commands: 0=clear, 1=credit, 2=debit, 3=balance, 4=exit\n\n");
	
	double balance = 0.0;
	double amount = 0.0;

	for (;;) {
		int cmd;
		printf("Enter command: ");
		scanf("%d", &cmd);

		switch (cmd) {
		case 0:
			balance = 0;
			break;
		case 1:
			printf("Enter amount of credit: ");
			scanf("%lf", &amount);
			balance += amount;
			break;
		case 2:
			printf("Enter amount of debit: ");
			scanf("%lf", &amount);
			balance -= amount;
			break;
		case 3:
			printf("Current balance: $%.2lf\n", balance);
			break;
		case 4:
			exit(0);
		default:
			printf("Commands: 0=clear, 1=credit, 2=debit, 3=balance, 4=exit\n\n");
			break;
		}
	}
	return 0;
}

题目二:

(1) 给你一个 非空整数数组 nums,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

输入:nums = [1,4,2,1,2]
输出:4

(2) 给你一个整数数组 nums,其中恰好有两个元素只出现一次,其余所有元素均出现两次。 找出只出现一次的那两个元素。你可以按任意顺序返回答案.

输入:nums = [1,2,1,3,2,5]
输出:[3, 5]
解释:[5, 3] 也是有效的答案
代码二/解答:

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#define SIZE(a) (sizeof(a)/sizeof(a[0]))

int main(void) {
	//ONE SINGLE_DOG
	int nums[] = { 1,4,2,1,2 };
	int single_dog = 0; int lenght = 0;

	for (lenght = 0; lenght < SIZE(nums); lenght++) {
		single_dog = single_dog ^ nums[lenght];
	}

	printf("nums=[1,4,2,1,2]\nsingle_dog is %d\n", single_dog);


	//two single_dog
	int nums2[] = {1, 2, 1, 7, 2, 5};
	single_dog = 0; lenght = 0;

	for (lenght = 0; lenght < SIZE(nums2); lenght++) {
		single_dog = single_dog ^ nums2[lenght];
	}
	//printf("%d\n", single_dog);

	//找出single_dog最低有效位
	int lsb = 1; int count=0;
	while ((single_dog & lsb) == 0) {
		lsb <<=1; //single_dog>>=1;
		count++;
	}
	//printf("%d\n", count);

	//分组  -LSB的最低有效位
	int a=0; int b=0; lenght = 0;
	for (lenght = 0; lenght < SIZE(nums2); lenght++) {
		if (nums2[lenght] & lsb) {    
			a ^= nums2[lenght];  //在LSB位上是1   多次异或,除了SINGLE_DOG,其他的都会异或两次!!!妈的他不说
		}
		else {
			b^= nums2[lenght];    //在LSB位上是0
		}
		//nums2[length] & lsb 检查数组中的每个元素在 lsb 位上是1还是0。如果是1,则将其与 a 异或。如果是0,则将其与 b 异或。
	}
	printf("nums = [1,2,1,7,2,5]\ntwo single_dog is %d and %d\n", a,b);

	return 0;
}
答案:

(1)

#include <stdio.h>

int main(void) {
	int nums[] = { 1,2,1,3,2};

	int xor = 0;
	for (int i = 0; i < 5; i++) {
		xor ^= nums[i];
	}
	printf("xor = %d\n", xor);

	return 0;
}

(2) 

老师的找出最低有效位:

int lsb = xor &(-xor);

解释:

  1. -xor 的作用

    • 负号操作符 - 对 xor 进行取反操作(按位取反),并且将结果加 1,这是因为 -xor 在计算机中表示为补码形式,即 ~xor + 1。这个操作的结果是一个整数,其二进制表示仍然是原整数 xor 的最低有效位(LSB)的位置。
    • 这个结果确保了 -xor 保留了 xor 中最低有效位的1,并且将其右边的所有位都置为0,而它左边的所有位都变成了原 xor 的补码形式(即原来的0变成1,1变成0,但不影响最低有效位)。
  2. 按位与操作 &

    • xor & (-xor) 执行按位与操作。在按位与操作中,只有当两个操作数的对应位都为 1 时,结果的对应位才为 1,否则为 0。
  3. 结果 lsb

    • 结果 lsb 是一个整数,其二进制表示只有 xor 中的最低有效位为 1,其余位都为 0。这是因为 -xor 操作使得它只保留了 xor 中最低有效位的信息,其他位上的信息都被置为了 0。

示例:

假设 xor 的值为 0b101010,即十进制的 42。

  • xor = 0b101010 (42)
  • -xor = ~xor + 1 = 0b010110 + 1 = 0b010111 (-42 的补码表示)
  • xor & (-xor) = 0b101010 & 0b010110 = 0b000010 (结果为 2)

在这个示例中,lsb 的值为 2,对应于二进制数 0b000010,它是 xor 中最低有效位的位置。

我的:

int lsb = 1; int count=0;
    while ((single_dog & lsb) == 0) {
        lsb <<=1; //single_dog>>=1;
        count++;
    }

#include <stdio.h>

int main(void) {
	int nums[] = { 1,2,1,3,2,5 };

	int xor = 0;
	for (int i = 0; i < 6; i++) {
		xor ^= nums[i];
	}
	// xor = a ^ b; (xor肯定不等于0, 至少有一位为1, a和b在那一位上的值不一样)
	int lsb = xor &(-xor);

	int a = 0, b = 0;
	for (int i = 0; i < 6; i++) {
		if (nums[i] & lsb) {
			a ^= nums[i];
		} else {
			b ^= nums[i];
		}
	}

	printf("a = %d, b = %d\n", a, b);

	return 0;
}

题目三:

用户输入初始金额,利率和投资年数,程序将打印一张表格。表格将显示输入的利率以及紧随其后 4 个更高利率下的总金额。程序的会话如下:

Enter initial balance: 100
Enter interest rate: 6
Enter number of years: 5

Years    6%     7%     8%     9%    10%
  1    106.00 107.00 108.00 109.00 110.00
  2    112.36 114.49 116.64 118.81 121.00
  3    119.10 122.50 125.97 129.50 133.10
  4    126.25 131.08 136.05 141.16 146.41
  5    133.82 140.26 146.93 153.86 161.05

代码三/解答:

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>

int main(void) {
	int balance, rate, years;
	printf("Enter initial balance: ");
	scanf("%d", &balance);
	printf("Enter interest rate:");
	scanf("%d", &rate);
	printf("Enter number of years: ");
	scanf("%d", &years);

	int i; int temp_rate = rate;
	double money[5];
	int rate_arr[5];
	printf("\nYears ");
	for (i = 0; i < 5; i++) {
		money[i] = balance;
		rate_arr[i] = temp_rate;
		printf("   %d%%  ", temp_rate++);
		//printf("%d\t", rate_arr[i]);
	}
	printf("\n");

	i = 0;
	for(i = 0; i < years; i++) {
		printf("  %d   ", i + 1);
		int j;
		for (j = 0; j < years; j++) {
			money[j] =money[j]* (1.0 + rate_arr[j]/100.0);
			printf("%-8.2f", money[j]);
		}
		printf("\n");
	}
	return 0;
}

答案:

int main(void) {
	double init_balance;
	printf("Enter initial balance: ");
	scanf("%lf", &init_balance);

	int rate;
	printf("Enter interest rate: ");
	scanf("%d", &rate);

	int years;
	printf("Enter number of years: ");
	scanf("%d", &years);

	double balance[5];

	printf("\nYears   ");
	for (int i = 0; i < 5; i++) {
		printf("%4d%%  ", rate + i);
		balance[i] = init_balance;
	}
	printf("\n");

	for (int i = 1; i <= years; i++) {
		printf("%3d     ", i);
		for (int i = 0; i < 5; i++) {
			balance[i] += balance[i] * ((rate + i) / 100.0);//同时实现利率的递增
			printf("%7.2lf", balance[i]);
		}
		printf("\n");
	}

	return 0;
}

题目四:

写一个随机发牌的程序。用户指定发几张牌,程序打印手牌。程序的会话如下:

Enter number of cards in hand: 5
Your hand: 9c 7d 3c 5d kd
 代码四/解答:

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>   
#include <stdbool.h> 
#include <time.h>  
#define SIZE(a) (sizeof(a)/sizeof(a[0]))

//int random_number = min + rand() % (max - min + 1);
int main(void) {
	srand(time(NULL));
	const char rank[] = { '1','2','3','4','5','6','7','8','9','t','j','q','k','a' };
	const char suit[] = { 'd','c','h','s' };
	bool is_hand[13][4] = { false };  //注意不能TRUE

	int num;
	printf("Enter number of cards in hand:");
	scanf("%d", &num);
	printf("Your hand: ");
	int i;
	for (i = 0; i < num;i++) {
		int random_number =rand()%13;
		int random_number2 = rand() % 3;
		if (is_hand[random_number][random_number2] == false) {
			is_hand[random_number][random_number2] = true;
			printf("%c%c  ", rank[random_number], suit[random_number2]);
		}
		else {
			i--;
		}
	}
	printf("\n");
	return 0;
}
/*
写一个随机发牌的程序。用户指定发几张牌,程序打印手牌。程序的会话如下:

Enter number of cards in hand: 5
Your hand: 9c 7d 3c 5d kd
*/
 答案:
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <time.h>

int main(void) {	
	const char suits[4] = { 's', 'h', 'c', 'd' };
	const char ranks[13] = { '2', '3','4', '5','6','7','8','9','t','j','q','k','a' };
	bool in_hand[4][13] = { false };

	int cards;
	printf("Enter number of cards in hand: ");
	scanf("%d", &cards);
    
	printf("Your hand: ");
	srand(time(NULL));	// 设置随机种子
	while (cards) {
		int i = rand() % 4;
		int j = rand() % 13; // (i, j)
		if (!in_hand[i][j]) {
			in_hand[i][j] = true;
			cards--;
			printf("%c%c ", ranks[j], suits[i]);
		}
	}
	printf("\n");
    
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/711186.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

图论(一)之概念介绍与图形#matlab

图论&#xff08;一&#xff09;之概念介绍与图形目录 前言 一、图论介绍 二、基本概念 2.1图的概念 2.2图形分类 2.3邻接矩阵 2.3.1无向图 2.3.2有向图 2.3.3有向赋权图 2.4出度&#xff08;Outdegree&#xff09; 2.5入度&#xff08;Indegree&#xff09; 3.四种…

Apollo9.0 PNC源码学习之Control模块(五)—— 基于LQR的横向控制

前面文章&#xff1a; Apollo9.0 PNC源码学习之Control模块&#xff08;一&#xff09; Apollo9.0 PNC源码学习之Control模块&#xff08;二&#xff09; Apollo9.0 PNC源码学习之Control模块&#xff08;三&#xff09; Apollo9.0 PNC源码学习之Control模块&#xff08;四&…

GenICam标准(六)

系列文章目录 GenICam标准&#xff08;一&#xff09; GenICam标准&#xff08;二&#xff09; GenICam标准&#xff08;三&#xff09; GenICam标准&#xff08;四&#xff09; GenICam标准&#xff08;五&#xff09; GenICam标准&#xff08;六&#xff09; 文章目录 系列文…

鸿蒙用 BuilderParam 实现同一个布局不同内容组件

面通过一个案例展示BuilderParam的具体用法&#xff0c;例如&#xff0c;现需要实现一个通用的卡片组件&#xff0c;如下图所示 卡片中显示的内容不固定&#xff0c;例如 具体实现代码如下&#xff1a; Entry Component struct BuildParamDemo {build() {Column(){Card() {imag…

C++:STL容器-->set

使用set容器时需要导入头文件&#xff1a;#include <set> set和multiset区别&#xff1a; set不允许容器中有重复的元素 multiset允许容器中有重复的元素 1. 构造函数 set<T> st; set s(const &st); void printSet(set<int>& s) {for (set<int>…

CC2500和CC1101移植说明

主要通过如何移植、移植注意、关于芯片配置、如何生成导出配置四大步骤来说明CC2500和CC1101移植 首先通过下图1这个宏进行选择 如何移植 要移植的部分在 CC2500_hal.c 和 CC2500_hal.h中, 搜索 "//移植" 就可以定位到 库 所需的依赖, 需要根据 您的环境实现这些…

【机器学习】LightGBM: 优化机器学习的高效梯度提升决策树

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 LightGBM: 优化机器学习的高效梯度提升决策树引言一、LightGBM概览二、核心技术…

VSCode格式化插件-prettier

VSCode格式化插件 1.安装插件&#xff1a;prettier 2.设置默认格式化工具 设置中&#xff0c;搜索 “Default Formatter”。 在编辑器设置中&#xff0c;将默认格式化工具设为 Prettier。 3.启用格式化选项&#xff1a; 在设置中搜索 “Format On Save”&#xff0c;并勾选…

【机器学习】机器学习与物流科技在智能配送中的融合应用与性能优化新探索

文章目录 引言机器学习与物流科技的基本概念机器学习概述监督学习无监督学习强化学习 物流科技概述路径优化车辆调度需求预测 机器学习与物流科技的融合应用实时物流数据分析数据预处理特征工程 路径优化与优化模型训练模型评估 车辆调度与优化深度学习应用 需求预测与优化强化…

从 Solana 课程顺利毕业获得高潜岗位,他的 Web3 开发探险之旅

在 TinTinLand 的学习&#xff0c;给了我入门 Web3 行业的 Entry Ticket&#xff0c;我认为这张 Ticket 是非常宝贵和重要的。 Alex&#xff0c;一位从某家知名研究所毅然辞职&#xff0c;踏入Web3世界的年轻开发者&#xff0c;凭借在 TinTinLand 推出的「Solana 黑客松先锋训练…

leetcode(力扣)第15题-三数之和---使用c语言双指针法,二级指针的应用

题目&#xff1a; 15. 三数之和 - 力扣&#xff08;LeetCode&#xff09; 编写过程的问题&#xff1a; 记住线索 1、对数组使用快排排序&#xff1b;2、固定 a 对 b、c 使用双指针&#xff1b;3、注意去重问题。函数返回值的类型。{1&#xff0c;2&#xff0c;-3}。结果作为…

Unity动态添加聊天文本

1.创建一个滚动视图 2.调整滚动视图的位置并删掉这个 3.创建一个输入框和一个按钮 这里插一句一定要给content添加这个组件并设置单元格大小 4创建一个脚本并编写下面代码 using System.Collections; using System.Collections.Generic; using TMPro; using Unity.VisualScrip…

云原生系列之Docker常用命令

&#x1f339;作者主页&#xff1a;青花锁 &#x1f339;简介&#xff1a;Java领域优质创作者&#x1f3c6;、Java微服务架构公号作者&#x1f604; &#x1f339;简历模板、学习资料、面试题库、技术互助 &#x1f339;文末获取联系方式 &#x1f4dd; 系列文章目录 云原生之…

宠物空气净化器避坑指南:希喂、霍尼韦尔、安德迈谁是性价比之王

作为一个拥有两只布偶的猫奴&#xff0c;家中猫浮毛无处不在&#xff0c;稍有松懈&#xff0c;出门衣物上便沾满猫毛&#xff0c;影响形象。不仅如此&#xff0c;空气中还飘浮着猫咪们的浮毛和异味。难以清理。经过我不懈的努力&#xff0c;我终于找到了解决这一问题的神器——…

救命!挖到宝了,这本计算机书真的巨巨好看

一本适合大学生使用的计算机科学和编程学习指南&#xff0c;它通过丰富的内容和多样的学习形式&#xff0c;帮助学生建立坚实的计算机科学基础&#xff0c;并激发他们对计算机科学的兴趣。 这本书涵盖了多种类型的练习题&#xff0c;旨在帮助读者巩固理论知识并提高实际编程技能…

前端菜鸡流水账日记 -- pnpm的学习

哈咯哇大家&#xff0c;我又来了&#xff0c;最近稍微悠闲一些&#xff0c;所以就趁着这个机会学习一些新的知识&#xff0c;今天就是碰巧遇到了pnm&#xff0c;这个可以看作是npm的升级版本&#xff0c;比npm要快&#xff0c;用起来也更得劲更迅速 官网地址&#xff1a;https…

React入门教程:构建你的第一个React应用

在当今快速发展的Web开发领域&#xff0c;前端技术日新月异&#xff0c;而React作为一款强大的JavaScript库&#xff0c;已经成为众多开发者的首选。React以其组件化、高效的性能和灵活的数据处理机制闻名于世&#xff0c;被广泛用于构建动态且复杂的用户界面。在本教程中&…

Oracle数据库连接并访问Microsoft SQL Server数据库

Oracle数据库连接并访问Microsoft SQL Server数据库 说明&#xff1a;  1.实际开发中&#xff0c;Oracle数据库与SQLServer数据库之间可能需要相互进行访问&#xff0c;方便业务数据抽取&#xff0c;编写视图及表等操作。  2.SQLServer访问Oracle数据库配置相对较为简单&…

制作自己的 @OnClick、@OnLongClick(告别 setOnClickListener,使用注解、反射和动态代理)

前言 前面我们说过 ButterKnife 这个库&#xff0c;这个库实现不仅实现了 View 的绑定&#xff0c;而且还提供了大量的注解如 BindView、OnClick、OnLongClick 等来简化开发过程中事件绑定。而这些功能的实现是通过 APT 也就是注解处理器&#xff0c;在编译期间生成 Java 代码…

实用软件下载:XMind 2024最新安装包及详细安装教程

​XMind不仅是一款易用且功能强大的思维导图软件&#xff0c;也是一个开源项目。XMind以构建一个社区向全球提供领先的跨平台思维导图和头脑风暴软件为目标&#xff0c;以帮助用户提升效率。XMind公司是XMind开源项目的主要代码贡献者&#xff0c;与此同时&#xff0c;我们欢迎…