代码如下:
#包括< stdio, h >
Intmain()
{
Int,n。
扫描文件(“% d % d”,& s & n);
S-;//s-1;我们把周一到周日的时间设为0到6
S+=n;
S%=7;//通过调制来限定结果
S++;//转换回1-7表示
Printf("%d\n",s);//输出结果
返回0;
}
扩展资料:
在C语言中,char一般取1个字节,即8个二进制位。每一位都有两个0或1的值。利用乘法原理,排列组合的个数是1002^8=256个排列。
如果是无符号字符类型,即无符号字符类型,那么它总共可以表示256个无符号数字[0,255]。
如果它是带符号的字符类型,即带符号的字符或字符类型,它可以表示[-128,127],256个有符号的数字。
在有符号整数的表达式中,现在的计算机一般采用原代码、问题代码、补码三种编码方法。源代码的表示,最高位是符号位,0是正的,答案1是负的。因此,带符号的char类型的最大值的二进制位返回如下:
01111111//最高位是符号位,它是127
最小值的二进制位如下:
1000000//负值绝对值越大,值越小。是-128
在C语言中用到数值范围一般有如下两种情况:
1 逻辑判断中确定某数在某个范围内。
比如判断数c在[a,b]区间内可以写作
(a<=c) && (c <= b)
2 使计算结果处于某个范围内。
比如计算时间时,当前时间为n点,经过m小时后是几点,由于时间仅取值在0点到23点,所以对数值范围需要做约束。对于此可以用模除(%)来限定。
(n+m)%24
其它关于数值范围限定的问题,都可以从这两种情况中延伸获得。
比如下面两个例题就是两种情况的应用。
例一,输入起始天的星期数(1-7),及天数n,计算经过n天后是星期几。
分析,这个是第二种的典型应用,不过数据规模为1到7,与之前说的0起始情况略有不同,可以通过转换达到目的,代码如下:
#include
int main()
{
int s,n;
scanf("%d%d",&s,&n);
s --;//将s-1;这样用0-6代表星期一到日
s +=n;
s%=7;//通过模除限定结果
s++;//转换回1-7的表示方法
printf("%d\n", s);//输出结果
return 0;
}
例二,依照下面的公式计算,直到结果小于0或者大于100为止,f(0)由外部输入。
如果f(n)为奇数,f(n+1)=2f(n)
否则f(n+1) = f(n)/2-10
输出计算结果。
题目很清晰,直接输入并循环计算,直到符合退出条件为止。 对于条件的判断就是第一种情况的简单应用了。
代码如下:
#include
int main()
{
int r;
scanf("%d",&r);
while(r >= 0 && r <= 100)//对结果进行范围判断
{
if(r & 1) r *= 2; //奇数的情况。
else r=r/2-10;//偶数的情况。
}
printf("%d\n", r);
return 0;
}
else if((week=6)||(week=7))
改成
else if(week == 6 || week == 7)