C语言学习历程——Training02位运算03
来源:互联网 发布:红帽子linux iso下载 编辑:程序博客网 时间:2024/06/04 19:50
3. 题目:输入一个整数a,再输入两个整数p1,p2(p1,p2<32);
将该整数的二进制表示方法中从右端开始的p1到p2位取反后输出
分析:先将二进制存入数组中,之后输出时取反输出就可以了
下面是代码实现:
/***************************************************
输入一个整数a,再输入两个整数p1,p2(p1,p2<32);
输出该整数的二进制表示方法中从右端开始的p1到p2位.
***************************************************/
#include <stdio.h>
void PrintBin(int a, int p1, int p2)
{
int Arr[32] = {0};
int i = 9;
for (i = 0; i < 32; i++)
{
Arr[i] = a % 2;
a >>= 1;
}
for (i = p1 - 1; i <= p2 - 1; i++)
{
printf ("%d", Arr[i] == 0 ? 1 : 0); //取反 0->1 1->0
}
printf ("\n");
}
int main()
{
int a = 0;
int p1, p2;
loop:
printf ("please input a integer:");
scanf ("%d", &a);
printf ("input p1(p1 < 32):");
scanf ("%d", &p1);
printf ("input p2(p2 < 32):");
scanf ("%d", &p2);
if (p1 <= 0 || p2 <= 0|| p1 > 32 || p2 > 32 || p1 > p2)
{
printf ("input error!\n");
goto loop;
}
PrintBin(a, p1, p2);
return 0;
}
输入一个整数a,再输入两个整数p1,p2(p1,p2<32);
输出该整数的二进制表示方法中从右端开始的p1到p2位.
***************************************************/
#include <stdio.h>
void PrintBin(int a, int p1, int p2)
{
int Arr[32] = {0};
int i = 9;
for (i = 0; i < 32; i++)
{
Arr[i] = a % 2;
a >>= 1;
}
for (i = p1 - 1; i <= p2 - 1; i++)
{
printf ("%d", Arr[i] == 0 ? 1 : 0); //取反 0->1 1->0
}
printf ("\n");
}
int main()
{
int a = 0;
int p1, p2;
loop:
printf ("please input a integer:");
scanf ("%d", &a);
printf ("input p1(p1 < 32):");
scanf ("%d", &p1);
printf ("input p2(p2 < 32):");
scanf ("%d", &p2);
if (p1 <= 0 || p2 <= 0|| p1 > 32 || p2 > 32 || p1 > p2)
{
printf ("input error!\n");
goto loop;
}
PrintBin(a, p1, p2);
return 0;
}
0 0
- C语言学习历程——Training02位运算03
- C语言学习历程——Training02位运算01
- C语言学习历程——Training02位运算02
- C语言学习历程——Training02位运算04
- C语言学习历程——Training02位运算05
- C语言学习历程——Training04字符串训练03
- C语言学习历程——字符串训练03
- C语言——位运算
- C语言—位运算、char、数组
- C语言位运算的学习
- C语言学习笔记11--位运算
- C语言学习笔记 位运算
- C语言位运算
- C语言位运算
- C语言位运算
- c语言位运算
- C语言位运算
- c语言位运算
- 从感知机到BP神经网络,简单BP神经网络的实现
- [勇者闯LeetCode] 118. Pascal's Triangle
- 刘汝佳《算法竞赛入门经典(第二版)》习题(四)
- 【OM】SoftEtherVPN搭建教程(3)
- AOJ-problem-850
- C语言学习历程——Training02位运算03
- Java : 一个帝国的诞生
- K
- linux 文件操作,IO多路复用,IPC 进程间通信
- 孩子们的游戏(圆圈中最后剩下的数)。。。约瑟夫环
- CCF NOI1034 钞票兑换
- linux免root权限安装运行mysql-5.7
- X
- h5中的一些配置