p24 p25作业讲解(2)

news2024/11/13 23:54:44
#include<stdio.h>
#include<stdlib.h>
int count_bit_one(int n)
{	int count=0;
	while(n)
	{
		if(n%2==1)
		{
			count++;
		}
		n=n/2;

	}
	return count;

}
int main(){
	int a=0;
	scanf("%d",&a);
	//写一个函数求a的二进制(补码)表示中有几个1
	int count=count_bit_one(a);

	printf("count=%d\n",count);

	system("pause");//system库函数-执行系统命令-pause(暂停)
	return 0;
}



结果:

#include<stdio.h>
#include<stdlib.h>
int count_bit_one(unsigned int n)
{    int count=0;
    int i=0;
    for(i=0;i<32;i++){
        if(((n>>i)&1)==1)
        {
            count++;
        }
    }
    return count;

}
int main(){
    int a=0;
    scanf("%d",&a);
    //写一个函数求a的二进制(补码)表示中有几个1
    int count=count_bit_one(a);

    printf("count=%d\n",count);

    system("pause");//system库函数-执行系统命令-pause(暂停)
    return 0;
}




 

#include<stdio.h>
#include<stdlib.h>
int count_bit_one(unsigned int n)
{    int count=0;
    int i=0;
    while(n){
        n=n&(n-1);
        count++;
    }
    return count;

}
int main(){
    int a=0;
    scanf("%d",&a);
    //写一个函数求a的二进制(补码)表示中有几个1
    int count=count_bit_one(a);

    printf("count=%d\n",count);

    system("pause");//system库函数-执行系统命令-pause(暂停)
    return 0;
}


求二进制中不同位的个数

题目内容:

标称实现:两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?

输入例子

1999 2299

输出例子:7

int get_dii_bit(int m,int n)
{
	int count=0;
	int tmp=m^n;
	//return count_bit_one(tmp);
	while(tmp){
		tmp=tmp&(tmp-1);
		count++;
	}
}
int main(){
	int m=0;
	int n=0;
	scanf("%d%d",&m,&n);
	int count=get_diff_bit(m,n);
	printf("count=%d\n",count);
}






交换二进制的奇数位和偶数位

题目内容:

获取一个整数二进制序列中所有的偶数位和奇数位,分别打印出二进制序列

void print(int m)
{
	int i=0;
	printf("奇数位:\n");

	for(i=30;i>=0;i=-2)
	{
		printf("%d",(m>>i)&1);
	}
	printf("\n");
	printf("偶数位:\n");
	for(i=31;i>=1;i=-2){
		printf("%d",(m>>i)&1);
	}
	printf("\n");
}
int main()
{
	int m=0;
	scanf("%d",&m);
	print(m);

	return 0;
}


print(int *p,int sz)
{
	int i=0;
	for(i=0;i<sz;i++)
	{
		printf("%d",*(p+i));
	}

}
int main()
{
	int arr[]={1,2,3,4,5,6,7,8,9};
	int sz=sizeof(arr)/sizeof(arr[0]);
	print(arr,sz);
	return 0;
}

递归调用 

void print_table(int n)
{
	int i=0;
	for(i=1;i<=n;i++)
	{
		int j=0;
		for(j=1;j<=i;j++)
		{
			printf("%d*%d=%-3d",i,j,i*j);
		}
		printf("\n");
	}
}
int main()
{
	int n=0;
	scanf("%d",&n);
	print_table(n);
	return 0;
}

乘法口诀表 

void print_table(int n)
{
	int i=0;
	for(i=1;i<=n;i++)
	{
		int j=0;
		for(j=1;j<=i;j++)
		{
			printf("%d*%d=%-3d",i,j,i*j);
		}
		printf("\n");
	}
}
int main()
{
	int n=0;
	printf("请输入几乘几的乘法口诀表:");
	scanf("%d",&n);
	print_table(n);
	return 0;
}

逆转字母顺序

abcdef

fedcba

int my_strlen(char *str)
{
	int count =0;
	while(*str!='\0'){
		count++;
		str++;

	}
	return count;

}
void reverse_string(char arr[])
{
	int left=0;
	int right=strlen(arr)-1;
	while(left<right)
	{
	int tmp=arr[left];
	arr[left]=arr[right];
	arr[right]=tmp;
	left++;
	right--;
	}


}
int main(){
	char arr[]="abcdef";//fedcba
	reverse_string(arr);
	printf("%s\n",arr);
return 0;
}

递归调用方法:

void reverse_string(char *arr)
{
    char tmp=arr[0];
    int len=my_strlen(arr);
    arr[0]=arr[len-1];
    arr[len-1]='\0';
    if(my_strlen(arr+1)>=2)
        reverse_string(arr+1);
    arr[len-1]=tmp;
}
int main()
{
    char arr[]="abcdefg";
    reverse_string(arr);
    printf("%s\n",arr);
    return 0;
}
 

写一个递归函数DigitSum(n),输入一个非负整数,返回组成他的数字之和

例如,调用DigitSum(1729),则应该返回1+7+2+9,它的和是19

输入:1729 输出19

DigitSum(1729)

DigitSum(172)+172%10

DigitSum(17)+172%10+1729%10

DigitSum(1)+17%10+...

1+7+2+9

int DigitSum(unsigned int num)
{
	if(num>9)
	{
		return DigitSum(num/10)+num%10;
	}
	else
	{
		return num;
	}

}

int main(){
	unsigned int num=0;
	scanf("%d",&num);
	int ret=DigitSum(num);
	printf("ret=%d\n",ret);


	return 0;
}



1234

ret=10

#include<stdio.h>
double Pow(int n,int k)

{
	if(k<0)
		return (1.0/Pow(n,-k));
	if(k==0)
		return 1;
	else
		return n*Pow(n,k-1);
}
int main()
{
	int n=2;
	int k=-3;
	//scanf("%d%d",&n,&k);
	double Pow(n,k);
	printf("Pow(n,k)=%lf\n",Pow(n,k));
	return 0;
}


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C盘上的软件怎么移动到D盘?C盘满了,教你轻松转移软件到D盘

在日常使用电脑的过程中&#xff0c;我们经常会遇到C盘空间不足的情况。为了释放C盘的空间&#xff0c;或者为了更好地管理我们的软件和文件&#xff0c;我们可能需要将安装在C盘的软件移动到D盘。那么&#xff0c;C盘上的软件怎么移动到D盘呢&#xff1f;本文将介绍两种常用的…

Ubuntu-文件管理器中鼠标右键添加文本文件

文件管理器中鼠标右键添加文本文件 一、概述二、步骤 一、概述 Ubuntu在文管右键发现没有创建文本文件的菜单&#xff0c; 期望如下所示&#xff0c;这样的操作非常简单 二、步骤 找到模板文件夹 在模板文件夹&#xff0c;创建自己想要的文件就好啦 这个也是支持放文件夹去…

Microsoft 365 Office BusinessPro LTSC 2024 for Mac( 微软Office办公套件)

Microsoft 365 Office BusinessPro LTSC 2024是一款专为商业用户设计的办公软件套件&#xff0c;它集成了Word、Excel、PowerPoint等核心应用&#xff0c;并特别包含了Microsoft Teams这一强大的协作工具。Teams将聊天、会议、文件共享、任务管理等功能整合到一个平台上&#x…

听说宇哥突然大幅删减了新36讲?25张宇强化究竟行不行呀?

宇哥深夜划重点&#xff0c;大幅删减新36讲&#xff01; 宇哥最近舆论压力很大&#xff0c;很多人怕36讲暑假学不完了。 甚至一些人开始考虑&#xff0c;要不要转武忠祥&#xff1f; 张宇划的重点课&#xff0c;其实就是&#xff1a;概念要听&#xff0c;计算不用听。 因为强…

SQL Server 数据误删的恢复

在日常的数据库管理中&#xff0c;数据的误删操作是难以避免的。为了确保数据的安全性和完整性&#xff0c;我们必须采取一些措施来进行数据的备份和恢复。本文将详细介绍如何在 SQL Server 中进行数据的备份和恢复操作&#xff0c;特别是在发生数据误删的情况下。假设我们已经…

苹果微信数据恢复的教程?3个方法,一学就会!

各位家人朋友们&#xff01;你是否有遇到过微信数据误删或者是找不到的窘况呢&#xff1f;是不是时常会发现时间较为久远的微信聊天记录或者是文件已经过期无法打开呢&#xff1f;这些生活上的小烦恼大家都会有&#xff0c;但是大部分人都不知道该如何解决微信数据恢复问题。今…

大厂面试官问我:Mysql B+树索引中B最后一层是双向链表还是单向链表?为什么这么设计?【后端八股文十四:Mysql索引八股文合集】

本文为【Mysql索引八股文合集】初版&#xff0c;后续还会进行优化更新&#xff0c;欢迎大家关注交流~ hello hello~ &#xff0c;这里是绝命Coding——老白~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏…

局部加全局视角遮挡人脸表情识别方法

一、摘要 实际场景中各种遮挡增加了表情识别难度。为此&#xff0c;提出一种滑块局部加权卷积注意力和全局注意力 池化的视觉 Transformer 结合的方法来解决遮挡问题。 利用主干网络提取表情特征图&#xff0c;将表情特征图裁剪成 多个区域块&#xff0c;利用局部 Patch 注意力…

Mem0 - 个人 AI 的内存层

文章目录 一、关于 Mem0核心功能&#x1f511;路线图 &#x1f5fa;️常见用例Mem0与RAG有何不同&#xff1f; 二、快速入门 &#x1f680;1、安装2、基本用法&#xff08;开源&#xff09;3、高级用法&#x1f527;4、大模型支持 三、MultiOn1、概览2、设置和配置4、将记忆添加…

【嵌入式开发之并发程序设计】守护进程的定义、特点、相关概念及创建

守护进程的定义 守护进程(Daemon Process)&#xff0c;又叫精灵进程、监控进程&#xff0c;是Linux三种进程类型之一&#xff0c;是 Linux 中的后台服务进程&#xff0c;是一个生存期较长的进程&#xff0c;通常独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事…

亚信安全与软银中国全资企业爱思比通信达成战略合作

近日&#xff0c;亚信安全携手软银集团旗下全资企业爱思比通信科技&#xff08;上海&#xff09;有限公司&#xff08;以下简称“爱思比通信”&#xff09; 共同宣布&#xff0c;双方正式签署战略合作协议。依托双方在技术、业务和资源三大层面的实力与优势&#xff0c;亚信安全…

2024-07-23 Unity AI行为树2 —— 项目介绍

文章目录 1 项目介绍2 AI 代码介绍2.1 BTBaseNode / BTControlNode2.2 动作/条件节点2.3 选择 / 顺序节点 3 怪物实现4 其他功能5 UML 类图 项目借鉴 B 站唐老狮 2023年直播内容。 点击前往唐老狮 B 站主页。 1 项目介绍 ​ 本项目使用 Unity 2022.3.32f1c1&#xff0c;实现基…

韦东山嵌入式linux系列-查询方式的按键驱动程序_编写框架

1 LED 驱动回顾 对于 LED&#xff0c; APP 调用 open 函数导致驱动程序的 led_open 函数被调用。在里面&#xff0c;把 GPIO 配置为输出引脚。安装驱动程序后并不意味着会使用对应的硬件&#xff0c;而 APP 要使用对应的硬件&#xff0c;必须先调用 open 函数。所以建议在驱动…

算法-DFS搜索

题目一 解题思路 深度遍历剪枝优化 第r行&#xff0c;第i列能不能放棋子&#xff1a;用数组dg udg cor 分别表示&#xff1a;点对应的两个斜线以及列上是否有皇后。 边界问题&#xff1a; dg[i r] 表示 r行i列处&#xff0c;所在的对角线上有没有棋子 udg[n - i r]表示 r…

环信+亚马逊云科技服务:助力出海AI社交应用扬帆起航

随着大模型技术的飞速发展&#xff0c;AI智能体的社交体验得到了显著提升&#xff0c;AI社交类应用在全球范围内持续火热。尤其是年轻一代对新技术和新体验的热情&#xff0c;使得AI社交产品在海外市场迅速崛起。作为领先的即时通讯解决方案提供商&#xff0c;环信与亚马逊云科…

uni-app:踩坑路---scroll-view内使用fixed定位,无效的问题

前言&#xff1a; emmm&#xff0c;说起来这个问题整得还挺好笑的&#xff0c;本人在公司内&#xff0c;奋笔疾书写代码&#xff0c;愉快的提交测试的时候&#xff0c;测试跟我说&#xff0c;在苹果手机上你这个样式有bug&#xff0c;我倒是要看看&#xff0c;是什么bug。 安卓…

Golang | Leetcode Golang题解之第268题丢失的数字

题目&#xff1a; 题解&#xff1a; func missingNumber(nums []int) int {n : len(nums)total : n * (n 1) / 2arrSum : 0for _, num : range nums {arrSum num}return total - arrSum }

5.9 结构化开发方法

大纲 系统分析与设计概述&#xff08;选择题 1 分&#xff09; 结构化开发方法 系统分析阶段的主要工作 系统设计基本原理 内聚&#xff08;主要考点&#xff09;

【HarmonyOS学习】用户文件访问

概述 文件所有者为登录到该终端设备的用户&#xff0c;包括用户私有的图片、视频、音频、文档等。 应用对用户文件的创建、访问、删除等行为&#xff0c;需要提前获取用户授权&#xff0c;或由用户操作完成。 用户文件访问框架 是一套提供给开发者访问和管理用户文件的基础框…

深入Mysql-03-MySQL 表的约束与数据库设计

文章目录 数据库约束的概述约束种类主键约束唯一约束非空约束默认值外键约束 表与表之间的关系数据库设计 数据库约束的概述 对表中的数据进行限制&#xff0c;保证数据的正确性、有效性和完整性。一个表如果添加了约束&#xff0c;不正确的数据将无法插入到表中。 约束种类 …