今日複習之前的知識點
發現了一些之前沒有掌握的點
1、%7.2f 總位數爲7位,小數點後兩位,整數部分位數不足時空格在前面補齊,位數超過時,依舊輸出前面的位數
2、++i與i++;
++i值在當前行生效
i++值在當前行執行完生效
3、define與const的區別
1) 編譯器處理方式不同
define宏是在預處理階段展開。
const常量是編譯運行階段使用。
(2) 類型和安全檢查不同
define宏沒有類型,不做任何類型檢查,僅僅是展開。
const常量有具體的類型,在編譯階段會執行類型檢查。
(3) 存儲方式不同
define宏僅僅是展開,有多少地方使用,就展開多少次,不會分配內存。
const常量會在內存中分配(可以是堆中也可以是棧中)。
(4)const 可以節省空間,避免不必要的內存分配。 例如:
#define PI 3.14159 //常量宏
const doulbe Pi=3.14159; //此時並未將Pi放入ROM中 ......
double i=Pi; //此時爲Pi分配內存,以後不再分配!
double I=PI; //編譯期間進行宏替換,分配內存
double j=Pi; //沒有內存分配
double J=PI; //再進行宏替換,又一次分配內存!
const定義常量從彙編的角度來看,只是給出了對應的內存地址,而不是象#define一樣給出的是立即數,所以,const定義的常量在程序運行過程中只有一份拷貝,而 #define定義的常量在內存中有若干個拷貝。
(5) 提高了效率。 編譯器通常不爲普通const常量分配存儲空間,而是將它們保存在符號表中,這使得它成爲一個編譯期間的常量,沒有了存儲與讀內存的操作,使得它的效率也很高。
4、數學函數
ceit取上限
floor取下限
今日部分練習:
//
// main.m
// C08
//
// Created by 嚴誠 on 15/7/24.
// Copyright (c) 2015年 嚴誠. All rights reserved.
//
#import <Foundation/Foundation.h>
void test1(){
for (int i=1; i<10; i++) {
for (int j=1; j<=i;j++) {
printf("%d*%d=%d ",i,j,i*j);
}
printf("\n");
}
}
void test2(int a){
int b=0;
for (int i=1; i<=a/2; i++) {
if (a%i==0) {
b+=i;
}
}
if (b==a) {
printf("完數爲%d\n",a);
}
}
int find3(int *a){
for (int i=0; i<13; i++) {
if (a[i]%3==0) {
a[i]=0;
}
}
return *a;
}
void test4(){
int a[13];
for (int i=0; i<13; i++) {
a[i]=i+1;
}
for (int j=0;j<12; j++) {
*a=find3(a);
if (a[j]==0) {
for (int i=0; i<12;i++) {
a[j]=a[j+1];
}
}
}
printf("%d",a[0]);
}
void lx(){
int line=5;
int spacecount1=0,spacecount2=0;
for (int i=0; i<line; i++) {
spacecount1=line-i-1;
spacecount2=2*i-1;
for (int j=spacecount1; j>0; j--) {
printf(" ");
}
printf("*");
for (int j=spacecount2; j>0; j--) {
printf(" ");
}
if (i!=0) {
printf("*");
}
printf("\n");
}
}
//萬年曆
//星期幾的計算s=(year-1+(year-1)/4-(year-1)/100+(year-1)/400+daycount)%7
void wannianli(int year,int month,int day){
int runyear=0,daycount=0;
int allmonth[2][13]={{0,31,28,31,30,31,30,31,31,30,31,30,31},{0,31,29,31,30,31,30,31,31,30,31,30,31}};
if ((year%4==0&&year%100!=0)||year%400==0) {
runyear=1;
}
for (int i=1; i<=month; i++) {
daycount+=allmonth[runyear][i-1];
}
//daycount+=day;//一年中第幾天
//printf("%d \n",daycount);
//printf("%d",year-1 + (year-1)/4 - (year-1)/100 + (year-1)/400);
int monthweek[allmonth[runyear][month]];
for (int i=0; i<allmonth[runyear][month]; i++) {
monthweek[i]=(year-1 + (year-1)/4 - (year-1)/100 + (year-1)/400 + daycount+i+1)%7;
}
for (int i=0; i<=allmonth[runyear][month]; i++) {
printf("%d ",i+1);
if (monthweek[i]==0) {
monthweek[i]+=7;
}
printf("星期%d \t",monthweek[i]);
if ((i+1)%7==0) {
printf("\n");
}
}
printf("\n");
}
void Joseph (int n,int m){
int sum, a[n], i, del = 0;
for (i = 0; i <= n-1; i++)
a[i] = i + 1;
for (sum = n; sum != 1; sum--) {
del = (del + m-1) % sum;
printf("第%d個出局%d\n",n-i+1, a[del]);
for (i = del; i <= sum - 2; i++)
a[i] = a[i+1];
}
printf("留下的是%d\n\n", a[0]);
}
int main(int argc, const char * argv[]) {
@autoreleasepool {
// //test1();
// for (int i=1; i<1000; i++) {
// test2(i);
// }
// test4();
//wannianli(2015, 7,24);
lx();
Joseph(13, 3);
}
return 0;
}