Suppose that file_a.c and file_b.c can be compiled independently. and they share the following global variables
extern int x; char ch;
which are declared in file_a.c. The allowed global variables declared in file_b.c are
A、extern int x; char ch;
B、extern int x; extern char ch;
C、int x; char ch;
D、int x; extern char ch;
9.改错题注意悬挂指针
例如:
1 2 3 4
char *a[5]; int i = 0; for (i=0; i<5; i++) scanf("%s", a[i]);
10.Switch中的break
若switch中的case不加break,将会将该case后的所有语句全部执行完。
11.字段成员的内存分配
字段成员的内存分配是由低位到高位的。例如下面的题目,答案为C:
Suppose declared:
1 2 3 4 5 6 7
struct direction { unsigned short int east:4,south:4,west:4,north:4; //east为最低位4,north为最高位1 }; union ud{ unsigned short int all; struct direction d; } a={0x1234};
#include <stdio.h>; void swap(int *a, int *b); int main (void) { int number[10]; int i, j;//循环变量 while (scanf("%d", &number[0]) != EOF) { for (i = 1 ; i < 10 ; i++) scanf("%d", &number[i]); for (i = 0 ; i < 9 ; i++) { for (j = 0 ; j <= 8 - i ; j++) { if (number[j] > number[j+1]) swap(&number[j], &number[j+1]); } } for (i = 0 ; i < 10 ; i++) { if (i != 0) printf("->"); printf("%d", number[i]); } putchar('\n'); } return 0; } void swap(int *a, int *b) { int temp; temp = *a; *a = *b; *b = temp; return; }
第二题
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
#include <stdio.h>; int main (void) { long number; char currentByte; int count; while (scanf("%ld", &number) != EOF) { for (count = 7 ; count >= 0 ; count--) { currentByte = (((0xf << (count * 4)) & number) >> (count * 4)) & 0xf; printf("%hd(%c) ", currentByte, currentByte); } putchar('\n'); } return 0; }
#include <stdio.h>; void swap(int *a, int *b); void moveArray(int a[], int n, int m);//轮移数组,其中n为总个数,m为轮移次数 int main (void) { int number[22]; int individualNumber, middleNumber; int i;//循环变量 while ((scanf("%d", &individualNumber), individualNumber) != 0) { scanf("%d", &middleNumber); for (i = 0 ; i < individualNumber ; i++) scanf("%d", &number[i]); moveArray(number, individualNumber, middleNumber); for (i = 0 ; i < individualNumber ; i++) { if (i != 0) putchar(' '); printf("%d", number[i]); } putchar('\n'); } return 0; } void moveArray(int a[], int n, int m) { if (m == 0) { return; } else { int temp, count; temp = a[0]; for (count = 0 ; count < n - 1 ; count++) a[count] = a[count+1]; a[n-1] = temp; moveArray(a, n, --m); } } void swap(int *a, int *b) { int temp; temp = *a; *a = *b; *b = temp; return; }
#include<stdio.h> #include<string.h> void swap(int *score_a, int *score_b, char *name_a, char *name_b); int main (void) { int number, count; while (scanf("%d", &number) != EOF) { putchar('\n'); int scores[number]; char names[number][81]; for (count = 0 ; count < number ; ++count) scanf("%s%d", names[count], &scores[count]); int i, j; for (i = 0 ; i < number ; ++i) for (j = i ; j < number ; ++j) if (scores[i] < scores[j]) swap(&scores[i], &scores[j], &names[i][0], &names[j][0]); for (count = 0 ; count < number ; ++count) printf("%s %d\n", names[count], scores[count]); putchar('\n'); } return 0; }
#include <stdio.h> int main (void) { int number,count; int current; int i; while (scanf("%d", &number) != EOF) { int people[10000]; for (i = 0 ; i < number ; ++i) people[i] = 1; count = number; current = 0; i = 0; while (count > 1) { if (i >= number) i = 0; if (people[i] == 1) current += 1; if (count == 1) break; if (current == 3) { people[i] = 0; count -= 1; current = 0; } i++; } for (i = 0 ; i < number ; ++i) if (people[i] == 1) { printf("%d\n", i + 1); break; } } return 0; }
#include <stdio.h> #define Swap(x,y) {x = x + y; y = x - y; x = x - y;}
int main (void) { int a, b; int count = 0; while (scanf("%d%d", &a, &b) != EOF) { if (count) putchar('\n'); count += 1; printf("Case %d:\n", count); printf("Before Swap:a=%d b=%d\n", a, b); Swap(a,b); printf("After Swap:a=%d b=%d\n", a, b);
#include <stdio.h> int main (void) { int sequence[20]; int number; int count; int i, j; int temp; while (scanf("%d", &number), number != 0) { for (count = 0 ; count < number ; ++count) scanf("%d", &sequence[count]); for (i = 0 ; i < number ; ++i) for (j = i ; j < number ; ++j) if (sequence[i] > sequence[j]) { temp = sequence[i]; sequence[i] = sequence[j]; sequence[j] = temp; } for (count = 0 ; count < number ; ++count) { if (count) putchar(' '); printf("%d", sequence[count]); } putchar('\n'); } return 0; }
int isPrime (int x); int main (void) { int begin, end; int count, number; int subnumber1, subnumber2; for (count = 1 ; scanf("%d%d", &begin, &end) != EOF ; ++count) { if (count != 1) putchar('\n'); printf("CASE:%d\n", count); printf("COLDBACH'S CONJECTURE:\n"); printf("Every even number n>=4 among %d~%d is the sum of two primes:\n", begin, end); if (begin % 2 != 0) begin++; for (number = begin ; number <= end ; number += 2) { for (subnumber1 = 2 ; subnumber1 <= (number/ 2) ; ++subnumber1) { subnumber2 = number - subnumber1; if (isPrime(subnumber2) && isPrime(subnumber1)) { printf("%d=%d+%d\n", number, subnumber1, subnumber2); break; } } } } return 0; }
/************************************************* Function: isPrime Description: 判断正整数是否为素数 Input: 一个正整数x Return: 1表示素数 0表示合数 *************************************************/ int isPrime (int x) { int i; for (i = 2 ; i <= sqrt(x) ; ++i) if (x % i == 0) return 0; return 1; }
#include <stdio.h> int getKFromN (unsigned long n , int k);
int main (void) { unsigned long n; int k; while (scanf("%lu%d", &n, &k) != EOF) { printf("%d\n", getKFromN(n, k)); } return 0; }
/************************************************* Function: getKFromN Description: 返回n中从右端开始的第k个值 Input: 一个1~4000000000的正整数n 一个正整数k Return: 一个正整数 n中的第k个数字 -1表示越位 *************************************************/ int getKFromN (unsigned long n , int k) { int unit = 0;//表示最后一位 int count;//表示当前位数 unsigned long result = n;//存储结果 for (count = 1 ; count <= k ; count++) { unit = result % 10; result = result / 10; } if (!(unit == 0 && result == 0)) return unit; else return -1; } ```
Hailstone generated by 92: 92 46 23 70 35 106 53 160 80 40 20 10 5 16 8 4 2 1 Number of hailstone generated:18
### 解答:
#include <stdio.h> unsigned long long getNextHailstoneNumber (unsigned long long n);
int main (void) { unsigned long long number; int count; int flag = 1; while (scanf(“%llu”, &number) != EOF) { if (!flag) putchar(‘\n’); printf(“Hailstone generated by %llu:\n”, number); count = 0; while (number != 1) { count += 1; printf(“%llu “, number); number = getNextHailstoneNumber(number); } printf(“1\n”); printf(“Number of hailstone generated:%d\n”, count + 1); flag = 0; } return 0; }
#include <stdio.h> long long getFactorial (int n);
int main (void) { int number; int i;//循环变量 double s; while (scanf(“%d”, &number) != EOF) { s = 0; for (i = 1 ; i <= number ; ++i) { s += 1.0 / getFactorial(i); } printf(“%.18f\n”, s); } return 0; }
/* Function: getFactorial Description: 返回n的阶乘 Input: 一个正整数n Return: 一个正整数n! */ long long getFactorial (int n) { int count; long long result = 1; for (count = 2 ; count <= n; ++count) { result *= count; } return result; }
int main (void) { int number; int count; int a, b; int dieA, dieB, dieSum; int winNumber; int n; scanf(“%d”, &number); for (count = 0 ; count < number ; ++count) { scanf(“%d%d”, &a, &b); dieA = calcSum(a) % 6 + 1; dieB = calcSum(b) % 6 + 1; dieSum = dieA + dieB; if (dieSum == 7 || dieSum == 11) { printf(“success!\n”); continue; } else if (dieSum == 2 || dieSum == 3 || dieSum == 12) { printf(“fail!\n”); continue; } else { winNumber = dieSum; } n = 1;//此处与题目描述不符 do { dieA = calcSum(a + n) % 6 + 1; dieB = calcSum(b + n) % 6 + 1; dieSum = dieA + dieB; n += 1; if (dieSum == 7) { printf(“fail!\n”); break; } }while (dieSum != winNumber); if (dieSum == winNumber) printf(“success!\n”); }
return 0;
}
/* Function: calcSum Description: 计算启动数的各位的和sum Input: 一个正整数n(启动数) Return: 一个正整数n(启动数各个位数的和) */ int calcSum (int startNumber) { int unit = 0; int result = startNumber; int sum = 0; while (result != 0) { unit = result % 10; sum += unit; result = result / 10; } return sum; } `
/* ZhihaoChen CSEE 1501 */ #include<stdio.h>; /* Prototype Declaration */ void if_else_process(double a, double b, char c); void switch_process(double a, double b, char c); /* Main Function */ int main(void) { int t, count; double a, b; char c; for (count = 0 ; (scanf("%d%lf%lf %c", &t, &a, &b, &c) != EOF) ; ++count) { if(count != 0) printf("\n"); switch (t) { case 0: if_else_process(a, b, c); break; case 1: switch_process(a, b, c); break; case 2: if_else_process(a, b, c); switch_process(a, b, c); break; default: break; } } return 0; } /* data processing and output */ void if_else_process (double a, double b, char c) { double output = 0.0; if (c == '+') output = a + b; if (c == '-') output = a - b; if (c == '*') output = a * b; if (c == '/') output = a / b; printf ("After if-else processing,the result is : %.2f\n", output); }
void switch_process (double a, double b, char c) { double output = 0.0; switch(c) { case '+': output = a + b; break; case '-': output = a - b; break; case '*': output = a * b; break; case '/': output = a / b; break; default: break; } printf("After switch processing,the result is : %.2f\n", output); }